Mozi.HttpEmbedded嵌入式 Web 服务器

联合创作 · 2023-10-01 14:36

Mozi.HttpEmbedded是一个基于.Net构建的嵌入式Web服务器,为.Net App提供web服务功能。

嵌入式的目标不是单片机,而是.Net应用程序。

此项目并不会实现非常丰富的大型Web服务器功能

项目基于.Net Framework 4.0开发,也可转换为.Net Core/.Net Standard项目

特点

HttpEmbedded在Socket之上使用异步单线程模型,构建了一个HTTP服务器。

  1. 嵌入式

    本项目可作为.Net应用的内嵌Web服务器,亦可作为单独Web服务器

  2. 轻量化

    项目编译结果小,部署程序占用系统资源少

  3. 可用性

    开箱即用,配置少,可控性高。同时遵从.Net平台Web项目开发的典型规范。

  4. 低耦合

    不改变现有业务逻辑,无需对现有代码进行改造,即可实现现有功能面向HTTP提供服务器

  5. 可控性

    宿主程序对Web服务高度可控

典型应用场景

业务体系或功能已开发完成,期望在项目中加入一个Web服务器功能,同时不能对现有代码进行大规模改动。

在经典的Asp.Net开发中,Web服务的部署高度依赖于IIS,.Net Core项目则可基于Kestrel/IIS部署。
基于KESTREL或IIS部署的WEB项目,都基于Asp.Net体系。

原理及功能

  1. HTTP协议 实现HTTP/1.1

  2. 通讯认证 实现基本认证(Basic)

  3. Cookie管理 支持标准Cookie

  4. HTTP请求方法 GET POST

  5. 路由 实现了URL管理,参见Router模块

  6. 引用与依赖关系 依赖于.Net Framework

  7. Payload压缩 使用GZip压缩

  8. 字符编码 字符编码部分使用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();

浏览 10
点赞
评论
收藏
分享

手机扫一扫分享

编辑
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑
举报