# FastHttpApi
**Repository Path**: kinnco/FastHttpApi
## Basic Information
- **Project Name**: FastHttpApi
- **Description**: 轻量级的webapi组件,性能高于asp.net core webapi 200%
- **Primary Language**: C#
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: https://ikende.com
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 30
- **Created**: 2019-07-13
- **Last Updated**: 2022-07-18
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
### introduction
Fasthttpapi is a lightweight and high-performance HTTP service component in the dotnet core platform that supports WebSocket and SSL. Performance higher than ap.net web api 200% [**[Samples](https://github.com/IKende/FastHttpApi/tree/master/samples)**]
https://ikende.com/doc/
## Nuget
https://www.nuget.org/packages/BeetleX.FastHttpApi/
## FrameworkBenchmarks
https://github.com/TechEmpower/FrameworkBenchmarks/tree/master/frameworks/CSharp/beetlex
## PerformanceTest
**[master/PerformanceTest](https://github.com/IKende/FastHttpApi/tree/master/PerformanceTest/Beetlex_VS_AspCore_webapi)**

## using
### Setting Server GC
`true`
### base code
``` csharp
[Controller]
class Program
{
private static BeetleX.FastHttpApi.HttpApiServer mApiServer;
static void Main(string[] args)
{
mApiServer = new BeetleX.FastHttpApi.HttpApiServer();
mApiServer.Options.LogLevel = BeetleX.EventArgs.LogType.Trace;
mApiServer.Options.LogToConsole = true;
mApiServer.Debug();//set view path with vs project folder
mApiServer.Register(typeof(Program).Assembly);
//mApiServer.Options.Port=80; set listen port to 80
mApiServer.Open();//default listen port 9090
Console.Write(mApiServer.BaseServer);
Console.Read();
}
// Get /hello?name=henry
// or
// Get /hello/henry
[Get(Route="{name}")]
public object Hello(string name)
{
return $"hello {name} {DateTime.Now}";
}
// Get /GetTime
public object GetTime()
{
return DateTime.Now;
}
}
```
### Hosting
`Install-Package BeetleX.FastHttpApi.Hosting -Version 0.8.2`
``` csharp
var builder = new HostBuilder()
.ConfigureServices((hostContext, services) =>
{
services
.AddSingleton()
.UseBeetlexHttp(o => {
o.Port = 8080;
o.LogToConsole = true;
o.LogLevel = BeetleX.EventArgs.LogType.Debug;
o.SetDebug();
}, typeof(Program).Assembly);
});
builder.Build().Run();
```
[samples](https://github.com/IKende/FastHttpApi/tree/master/samples)
## HTTPS
- HttpConfig.json
```
"SSL": true,
"CertificateFile": "you.com.pfx",
"CertificatePassword": "******",
```
- Code
``` csharp
mApiServer.ServerConfig.SSL=true;
mApiServer.ServerConfig.CertificateFile="you.com.pfx";
mApiServer.ServerConfig.CertificatePassword="******";
```
## Custom result
- Text result
``` csharp
public class TextResult : ResultBase
{
public TextResult(string text)
{
Text = text == null ? "" : text;
}
public string Text { get; set; }
public override bool HasBody => true;
public override void Write(PipeStream stream, HttpResponse response)
{
stream.Write(Text);
}
}
```
- Using
``` csharp
public object plaintext()
{
return new TextResult("Hello, World!");
}
```
## Cookies
``` csharp
public object SetCookie(string name, string value, IHttpContext context)
{
Console.WriteLine(context.Data);
context.Response.SetCookie(name, value);
return $"{DateTime.Now}{name}={value}";
}
public string GetCookie(string name, IHttpContext context)
{
Console.WriteLine(context.Data);
return $"{DateTime.Now} {name}= {context.Request.Cookies[name]}";
}
```
## Header
``` csharp
public void SetHeader(string token,IHttpContext context)
{
context.Response.Header["Token"]=token;
}
public string GetHeader(string name, IHttpContext context)
{
return context.Request.Header[name];
}
```
## Data bind
- url
`/hello?name=xxx`or`/hello/henry`
``` csharp
[Get(Route = "{name}")]
public object Hello(string name, IHttpContext context)
{
return $"hello {name} {DateTime.Now}";
}
```
`/SetValue?id=xxx&value=xxxx`or`/SetValue/xxx-xxx`
``` csharp
[Get(Route = "{id}-{value}")]
public object SetValue(string id, string value, IHttpContext context)
{
return $"{id}={value} {DateTime.Now}";
}
```
- Json
`{"name":"xxxx","value":"xxx"}`
``` csharp
[Post]
[JsonDataConvert]
public object Post(string name, string value, IHttpContext context)
{
Console.WriteLine(context.Data);
return $"{name}={value}";
}
```
or
``` csharp
[Post]
[JsonDataConvert]
public object Post(Property body, IHttpContext context)
{
Console.WriteLine(context.Data);
return $"{body.name}={body.value}";
}
```
- x-www-form-urlencoded
`name=aaa&value=aaa`
``` csharp
[Post]
[FormUrlDataConvert]
public object PostForm(string name, string value, IHttpContext context)
{
Console.WriteLine(context.Data);
return $"{name}={value}";
}
```
- multipart/form-data
``` csharp
[Post]
[MultiDataConvert]
public object UploadFile(string remark, IHttpContext context)
{
foreach (var file in context.Request.Files)
using (System.IO.Stream stream = System.IO.File.Create(file.FileName))
{
file.Data.CopyTo(stream);
}
return $"{DateTime.Now} {remark} {string.Join(",", (from fs in context.Request.Files select fs.FileName).ToArray())}";
}
```
- Read stream
``` csharp
[Post]
[NoDataConvert]
public object PostStream(IHttpContext context)
{
Console.WriteLine(context.Data);
string value = context.Request.Stream.ReadString(context.Request.Length);
return value;
}
```
## Filter
- custom filter
``` csharp
public class GlobalFilter : FilterAttribute
{
public override bool Executing(ActionContext context)
{
Console.WriteLine(DateTime.Now + " globalFilter execting...");
return base.Executing(context);
}
public override void Executed(ActionContext context)
{
base.Executed(context);
Console.WriteLine(DateTime.Now + " globalFilter executed");
}
}
```
- using
``` csharp
[CustomFilter]
public string Hello(string name)
{
return DateTime.Now + " hello " + name;
}
```
or
``` csharp
[Controller]
[CustomFilter]
public class ControllerTest
{
}
```
- skip filter
``` csharp
[SkipFilter(typeof(GlobalFilter))]
public string Hello(string name)
{
return DateTime.Now + " hello " + name;
}
```
## Parameters validation
``` csharp
public bool Register(
[StringRegion(Min = 5)]string name,
[StringRegion(Min = 5)]string pwd,
[DateRegion(Min = "2019-1-1", Max = "2019-2-1")]DateTime dateTime,
[EmailFormater]string email,
[IPFormater]string ipaddress,
[NumberRegion(Min = 18, Max = 56)]int age,
[DoubleRegion(Min = 10)]double memory
)
{
return true;
}
```
## async action
``` csharp
[Get(Route = "{name}")]
public Task Hello(string name)
{
string result = $"hello {name} {DateTime.Now}";
return Task.FromResult(result);
}
public async Task Wait()
{
await Task.Delay(2000);
return $"{DateTime.Now}";
}
```
## Cross domain
``` csharp
[Options(AllowOrigin = "www.ikende.com")]
public string GetTime(IHttpContext context)
{
return DateTime.Now.ToShortDateString();
}
```
## Websocket
- server
``` csharp
[Controller]
class Program
{
private static BeetleX.FastHttpApi.HttpApiServer mApiServer;
static void Main(string[] args)
{
mApiServer = new BeetleX.FastHttpApi.HttpApiServer();
mApiServer.Debug();
mApiServer.Register(typeof(Program).Assembly);
mApiServer.Open();
Console.Write(mApiServer.BaseServer);
Console.Read();
}
// Get /hello?name=henry
// or
// Get /hello/henry
[Get(R"{name}")]
public object Hello(string name)
{
return $"hello {name} {DateTime.Now}";
}
// Get /GetTime
public object GetTime()
{
return DateTime.Now;
}
}
```
- Hello
send json
``` javascript
{
url: '/Hello',
params: { name: 'test' }
}
```
- GetTime
send json
``` javascript
{
url: '/GetTime',
params: { }
}
```
## Using javascript VSIX
download https://github.com/IKende/FastHttpApi/blob/master/Extend/FastHttpApi.JSCreater.zip
unzip execute `FastHttpApi.JSCreaterVSIX.vsix` install to vs(support only vs2017),
change controller file custom tool property to 'JSAPI'