OWIN:HttpListener

概述

OWIN (Open Web Server Interface for .NET) 是一个规范和标准,OWIN 定义了 Web 服务器与 Web 应用之间的标准接口,将应用与服务器解耦,使得便携式 Web 应用以及跨平台的愿望成为现实,标准的 OWIN 应用可以在任何 OWIN 兼容的服务器上运行,不再依赖与 Windows 和 IIS 。

微软的 KatanaIdentitySignalR 等技术都是基于 OWIN 的标准中间件实现。

OWIN 4层结构

在 OWIN 规范下可将一个 Web 应用解耦为4层:

  1. Host(宿主):应用程序的主进程,主要负责 Server 的启动、关闭 ,为
    Server 加载各种 Middleware,同时也装载 Application。
  1. Server(服务器):绑定套接字并监听的HTTP请求,将请求的信息依照 OWIN 规范,包装成字典格式,传递到下层的 Middleware。
  1. Middleware(中间件):当从客户端发送一个请求,这个请求就会传到 OWIN 管道中处理,Middleware 就是组成管道的组件。
  1. Application(应用):具体的应用程序代码。
OWIN的4层结构

OWIN 规范约束

如下图,基于 OWIN,Web Framework 不再依赖 IIS 和 OS,这意味着理论上你可以使用任何其他 Web Server 来替换 IIS,OWIN 提供了明晰的规范以便我们快速灵活的去扩展管道来处理 Http 请求,甚至可以不写任何一句代码来切换不同的 Web Server,前提是这些 Web Server 遵循 OWIN 规范。

OWIN 规范约束

测试

下面我们分别以 IIS 为 Server 和 HttpListener 为 Server 来测试。可能我们比较熟悉的是以 IIS 作为 Server,按照上面的4层结构,应用部署到 IIS 的时候并没有设置Host,其实不用奇怪,因为 IIS 比较特殊,它既是 Server,也充当了 Host。

IIS
实现步骤:
  1. 新建一个空Web应用程序;
  2. Nuget 安装 Microsoft.Owin.Host.SystemWeb;
  3. 根目录下新建 Startup.cs 启动类

注册中间件到 OWIN 管道的三种方式:

  1. 默认名称匹配(Startup.cs),只要这个类的 namespace 和 Assembly 的名称相同,那类中的 Configuration 方法就会在 OWIN 管道初始化的时候执行。
public class Startup
{
  public void Configuration(IAppBuilder app)
  {
    // 注册中间件
    // app.Use<xxxxx>();

    app.Run(context =>
    {
      context.Response.ContentType = "text/palin";
      return context.Response.WriteAsync("Hello OWIN");
    });
  }
}
  1. 使用 OwinStartupAttribute
[assembly: OwinStartup(typeof(IISExample.Startup1))]
namespace IISExample
{
  public class Startup1
  {
    public void Configuration(IAppBuilder app)
    {
      // some code
    }
  }
}
  1. 配置文件的 appSetting 节点
<appSettings>
  <add key="owin:appStartup" value="IISExample.Startup2" />
</appSettings>
说明:

由于 IIS 既是 Host,又是 Server。所以 Microsoft.Owin.Host.SystemWeb 这个 Server 实现的是注册 ASP.NET HttpModule 和 HttpHandler,阻断原有的处理流程,转而把请求发送到 OWIN 管道中处理。

结果:

F5 运行


IIS Server
HttpListener
实现步骤:
  1. 新建一个控制台应用程序;
  2. NuGet 安装 Microsoft.Owin.Hosting 、Microsoft.Owin.Host.HttpListener;
  3. 设置 StartOptions
  4. Startup 函数注册
  5. 中间件注册
static void Main(string[] args)
{
  // 初始化StartOptions参数
  StartOptions options = new StartOptions();

  // 服务器Url设置
  options.Urls.Add("http://localhost:9000");
  options.Urls.Add("http://localhost:9001");
  options.ServerFactory = "Microsoft.Owin.Host.HttpListener";

  // 以Options和Startup启动Server
  using (WebApp.Start(options, Startup))
  {
    Console.WriteLine("Owin Host/Server started,press enter to exit it...");
    Console.ReadLine();
  }// Server在Dispose中关闭
}

private static void Startup(IAppBuilder app)
{
  Console.WriteLine("Sample Middleware loaded...");
  // 注册中间件
  app.Use<SampleMiddleware>();
}
说明:

Urls 参数是以 http 标准 url 为格式字符串来定义Server监听的 HostName 和 Port ,可以加多个,表示支持不同的 HostName 和 Port 映射。

ServerFactory 指定这个 Server 实现类的 assembly name。通过 HttpListener 打开 Socket 端口,监听请求,然后将请求包装发送到 OWIN 管道中处理。

当 using 的结尾触发 Dispose 时 Server 被自动关闭,Server 是独立线程运行的,所以宿主进程必须驻留。

以上代码没有依赖 Windows 和 IIS ,就能正常运行了。

结果:
HttpListener Server

参考链接:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,022评论 19 139
  • 0 系列目录# WEB请求处理 WEB请求处理一:浏览器请求发起处理 WEB请求处理二:Nginx请求反向代理 本...
    七寸知架构阅读 14,760评论 22 189
  • 明天就出院了,这次又在医院呆了一周。这次住院包了一间病房,不是姐姐钱多,实在是我不太习惯于陌生人住,有点小洁癖,最...
    栗子颜阅读 1,688评论 2 7
  • 你看见那抹黄色的光芒了吗 那是为你点亮
    孤单她呀开出了花阅读 2,241评论 2 1
  • 午后梦中迟迟不醒,一直在看一场不知道名字的电影或者是在听一场重复的课。很奇怪的姿势,半躺着,双目无神地注视前方...
    LKoala阅读 1,058评论 0 1

友情链接更多精彩内容