Mozi.HttpEmbedded嵌入式 Web 服务器
Mozi.HttpEmbedded是一个基于.Net构建的嵌入式Web服务器,为.Net App提供web服务功能。
嵌入式的目标不是单片机,而是.Net应用程序。
此项目并不会实现非常丰富的大型Web服务器功能
项目基于.Net Framework 4.0开发,也可转换为.Net Core/.Net Standard项目
特点
HttpEmbedded在Socket之上使用异步单线程模型,构建了一个HTTP服务器。
- 嵌入式 
本项目可作为.Net应用的内嵌Web服务器,亦可作为单独Web服务器
 - 轻量化 
项目编译结果小,部署程序占用系统资源少
 - 可用性 
开箱即用,配置少,可控性高。同时遵从.Net平台Web项目开发的典型规范。
 - 低耦合 
不改变现有业务逻辑,无需对现有代码进行改造,即可实现现有功能面向HTTP提供服务器
 - 可控性 
宿主程序对Web服务高度可控
 
典型应用场景
业务体系或功能已开发完成,期望在项目中加入一个Web服务器功能,同时不能对现有代码进行大规模改动。
在经典的Asp.Net开发中,Web服务的部署高度依赖于IIS,.Net Core项目则可基于Kestrel/IIS部署。 基于KESTREL或IIS部署的WEB项目,都基于Asp.Net体系。
原理及功能
-  
HTTP协议 实现HTTP/1.1
 -  
通讯认证 实现基本认证(Basic)
 -  
Cookie管理 支持标准Cookie
 -  
HTTP请求方法 GET POST
 -  
路由 实现了URL管理,参见Router模块
 -  
引用与依赖关系 依赖于.Net Framework
 -  
Payload压缩 使用GZip压缩
 -  
字符编码 字符编码部分使用UTF-8
 
功能与版本迭代
不定期对HttpEmbedded的功能进行完善,解决各种BUG。HTTP标准功能繁多,需要一步步实现。
版权说明
本项目采用MIT开源协议,欢迎复制,引用和修改。
使用说明
    HttpServer hs = new HttpServer();
    //配置端口并启动服务器
    hs.SetPort(9000).Start();
    //开启认证
    hs.UseAuth(AuthorizationType.Basic).SetUser("admin", "admin");
    //开启静态文件支持
    hs.UseStaticFiles("");
    //路由映射
    Router router = Router.Default;
    router.Map("services/{controller}/{id}");
    Console.ReadLine();
 
 评论
