ASP.NET Core 高階(一)【.NET 的開放 Web 介面 (OWIN)】
ASP.NET Core 中 .NET 的開放 Web 介面 (OWIN)
ASP.NET Core
支援 .NET 的開放 Web 介面 (OWIN
)。 OWIN
允許 Web 應用從 Web 伺服器分離。 它定義了在管道中使用中介軟體來處理請求和相關響應的標準方法。 ASP.NET Core
應用程式和中介軟體可以與基於 OWIN 的應用程式、伺服器和中介軟體進行互操作。
OWIN
提供了一個分離層,可一起使用具有不同物件模型的兩個框架。 Microsoft.AspNetCore.Owin
包提供了兩個介面卡實現:
此方法可將 ASP.NET Core 託管在相容 OWIN
的伺服器/主機上,或在 ASP.NET Core 上執行其他相容 OWIN
的元件。
備註
使用這些介面卡會帶來效能成本。 僅使用 ASP.NET Core 元件的應用不應使用Microsoft.AspNetCore.Owin
包或介面卡。
在 ASP.NET Core 管道中執行 OWIN
中介軟體
ASP.NET Core 的 OWIN 支援作為 Microsoft.AspNetCore.Owin
包的一部分進行部署。 可通過安裝此包將 OWIN 支援匯入到專案中。
OWIN 中介軟體符合 OWIN 規範,該規範要求使用 Func<IDictionary<string, object>, Task>
介面,並設定特定的鍵(如 owin.ResponseBody
)。 以下簡單的 OWIN 中介軟體顯示“Hello World”:
public Task OwinHello(IDictionary<string, object> environment)
{
string responseText = "Hello World via OWIN";
byte[] responseBytes = Encoding.UTF8.GetBytes(responseText);
// OWIN Environment Keys: http://owin.org/spec/spec/owin-1.0.0.html
var responseStream = (Stream)environment["owin.ResponseBody"];
var responseHeaders = (IDictionary<string, string[]>)environment["owin.ResponseHeaders"];
responseHeaders["Content-Length"] = new string[] { responseBytes.Length.ToString(CultureInfo.InvariantCulture) };
responseHeaders["Content-Type"] = new string[] { "text/plain" };
return responseStream.WriteAsync(responseBytes, 0, responseBytes.Length);
}
示例簽名返回 Task
,並接受 OWIN 所要求的 IDictionary<string, object>
。
以下程式碼顯示瞭如何使用 UseOwin
擴充套件方法將 OwinHello
中介軟體(如上所示)新增到 ASP.NET Core
管道。
public void Configure(IApplicationBuilder app)
{
app.UseOwin(pipeline =>
{
pipeline(next => OwinHello);
});
}
可配置在 OWIN
管道中要進行的其他操作。
備註
響應標頭只能在首次寫入響應流之前進行修改。
備註
由於效能原因,不建議多次呼叫UseOwin
。 組合在一起時OWIN
元件的效能最佳。
app.UseOwin(pipeline =>
{
pipeline(async (next) =>
{
// do something before
await OwinHello(new OwinEnvironment(HttpContext));
// do something after
});
});
在基於 OWIN 的伺服器中使用 ASP.NET Core 託管
基於 OWIN 的伺服器可託管 ASP.NET Core 應用。 Nowin(.NET OWIN Web 伺服器)屬於這種伺服器。 本文的示例中包含了一個引用 Nowin 的專案,並使用它建立了一個自託管 ASP.NET Core 的 IServer
。
IServer
是需要 Features
屬性和 Start
方法的介面。
Start
負責配置和啟動伺服器,在此情況下,此操作通過一系列 Fluent API 呼叫完成,這些呼叫設定從 IServerAddressesFeature 分析的地址。 請注意,_builder
變數的 Fluent 配置指定請求將由方法中之前定義的 appFunc
來處理。 對於每個請求,都會呼叫此 Func
以處理傳入請求。
我們還將新增一個 IWebHostBuilder
擴充套件,以便新增和配置 Nowin 伺服器。
using System;
using Microsoft.AspNetCore.Hosting.Server;
using Microsoft.Extensions.DependencyInjection;
using Nowin;
using NowinSample;
namespace Microsoft.AspNetCore.Hosting
{
public static class NowinWebHostBuilderExtensions
{
public static IWebHostBuilder UseNowin(this IWebHostBuilder builder)
{
return builder.ConfigureServices(services =>
{
services.AddSingleton<IServer, NowinServer>();
});
}
public static IWebHostBuilder UseNowin(this IWebHostBuilder builder, Action<ServerBuilder> configure)
{
builder.ConfigureServices(services =>
{
services.Configure(configure);
});
return builder.UseNowin();
}
}
}
完成此操作後,呼叫 Program.cs 中的擴充套件以使用此自定義伺服器執行 ASP.NET Core 應用:
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Hosting;
namespace NowinSample
{
public class Program
{
public static void Main(string[] args)
{
var host = new WebHostBuilder()
.UseNowin()
.UseContentRoot(Directory.GetCurrentDirectory())
.UseIISIntegration()
.UseStartup<Startup>()
.Build();
host.Run();
}
}
}
瞭解有關 ASP.NET Core 伺服器
的更多資訊。
在基於 OWIN 的伺服器上執行 ASP.NET Core 並使用其 WebSocket 支援
ASP.NET Core 如何利用基於 OWIN 的伺服器功能的另一個示例是訪問 WebSocket
等功能。 前面示例中使用的 .NET OWIN Web 伺服器支援內建的 Web 套接字,可由 ASP.NET Core
應用程式利用。 下面的示例顯示了簡單的 Web 應用,它支援 Web 套接字並回顯通過 WebSocket
傳送到伺服器的所有內容。
public class Startup
{
public void Configure(IApplicationBuilder app)
{
app.Use(async (context, next) =>
{
if (context.WebSockets.IsWebSocketRequest)
{
WebSocket webSocket = await context.WebSockets.AcceptWebSocketAsync();
await EchoWebSocket(webSocket);
}
else
{
await next();
}
});
app.Run(context =>
{
return context.Response.WriteAsync("Hello World");
});
}
private async Task EchoWebSocket(WebSocket webSocket)
{
byte[] buffer = new byte[1024];
WebSocketReceiveResult received = await webSocket.ReceiveAsync(
new ArraySegment<byte>(buffer), CancellationToken.None);
while (!webSocket.CloseStatus.HasValue)
{
// Echo anything we receive
await webSocket.SendAsync(new ArraySegment<byte>(buffer, 0, received.Count),
received.MessageType, received.EndOfMessage, CancellationToken.None);
received = await webSocket.ReceiveAsync(new ArraySegment<byte>(buffer),
CancellationToken.None);
}
await webSocket.CloseAsync(webSocket.CloseStatus.Value,
webSocket.CloseStatusDescription, CancellationToken.None);
}
}
使用與前一個相同的 NowinServer
來配置此示例 - 唯一的區別是如何在其 Configure
方法中配置應用程式。 使用簡單的 websocket 客戶端的測試演示應用程式:
OWIN 環境
可使用 HttpContext
來構造 OWIN 環境。
var environment = new OwinEnvironment(HttpContext);
var features = new OwinFeatureCollection(environment);
OWIN 鍵
OWIN 依賴於 IDictionary<string,object>
物件,以在整個 HTTP請求/響應交換中傳達資訊。 ASP.NET Core 實現以下所列的鍵。 請參閱主規範、擴充套件和 OWIN Key Guidelines and Common Keys(OWIN 鍵指南和常用鍵)。
請求資料 (OWIN v1.0.0)
鍵 | 值(型別) | 說明 |
---|---|---|
owin.RequestScheme | String |
|
owin.RequestMethod | String |
|
owin.RequestPathBase | String |
|
owin.RequestPath | String |
|
owin.RequestQueryString | String |
|
owin.RequestProtocol | String |
|
owin.RequestHeaders | IDictionary<string,string[]> |
|
owin.RequestBody | Stream |
請求資料 (OWIN v1.1.0)
鍵 | 值(型別) | 說明 |
---|---|---|
owin.RequestId | String |
Optional |
響應資料 (OWIN v1.0.0)
鍵 | 值(型別) | 說明 |
---|---|---|
owin.ResponseStatusCode | int |
Optional |
owin.ResponseReasonPhrase | String |
Optional |
owin.ResponseHeaders | IDictionary<string,string[]> |
|
owin.ResponseBody | Stream |
其他資料 (OWIN v1.0.0)
鍵 | 值(型別) | 說明 |
---|---|---|
owin.CallCancelled | CancellationToken |
|
owin.Version | String |
常用鍵
鍵 | 值(型別) | 說明 |
---|---|---|
ssl.ClientCertificate | X509Certificate |
|
ssl.LoadClientCertAsync | Func<Task> |
|
server.RemoteIpAddress | String |
|
server.RemotePort | String |
|
server.LocalIpAddress | String |
|
server.LocalPort | String |
|
server.IsLocal | bool |
|
server.OnSendingHeaders | Action<Action<object>,object> |
SendFiles v0.3.0
鍵 | 值(型別) | 說明 |
---|---|---|
sendfile.SendAsync | 請參閱委託簽名 | 每請求 |
Opaque v0.3.0
鍵 | 值(型別) | 說明 |
---|---|---|
opaque.Version | String |
|
opaque.Upgrade | OpaqueUpgrade |
請參閱委託簽名 |
opaque.Stream | Stream |
|
opaque.CallCancelled | CancellationToken |
WebSocket v0.3.0
鍵 | 值(型別) | 說明 |
---|---|---|
websocket.Version | String |
|
websocket.Accept | WebSocketAccept |
請參閱委託簽名 |
websocket.AcceptAlt | 非規範 | |
websocket.SubProtocol | String |
請參閱 RFC6455 4.2.2 節步驟 5.5 |
websocket.SendAsync | WebSocketSendAsync |
請參閱委託簽名 |
websocket.ReceiveAsync | WebSocketReceiveAsync |
請參閱委託簽名 |
websocket.CloseAsync | WebSocketCloseAsync |
請參閱委託簽名 |
websocket.CallCancelled | CancellationToken |
|
websocket.ClientCloseStatus | int |
Optional |
websocket.ClientCloseDescription | String |
Optional |
相關文章
- ASP.NET Core Web API 介面限流ASP.NETWebAPI
- Asp.Net Core中Typed HttpClient高階用法ASP.NETHTTPclient
- ASP.NET Core Web Api之JWT(一)ASP.NETWebAPIJWT
- ASP.NET Core Web API 索引 (更新Redis in .NET Core)ASP.NETWebAPI索引Redis
- ASP.NET Core 高階(二)【基於工廠的中介軟體】ASP.NET
- ASP.NET Core OData 9的釋出,放棄 .NET FrameworkASP.NETFramework
- ASP.NET Core Web API 與 SSLASP.NETWebAPI
- 【ASP.NET Core】體驗一下 Mini Web APIASP.NETWebAPI
- ASP.NET MVC隨想錄——漫談OWINASP.NETMVC
- ASP.NET Core - 開篇ASP.NET
- ASP.NET Core Web API 整合測試ASP.NETWebAPI
- ASP.NET Core Web API中使用SwaggerASP.NETWebAPISwagger
- ASP.NET Core Web API 教程 - Project ConfigurationASP.NETWebAPIProject
- ASP.NET Core 入門教程 2、使用ASP.NET Core MVC框架構建Web應用ASP.NETMVC框架架構Web
- The Open Web Interface for .NET (OWIN) 原始碼閱讀Web原始碼
- 使用 ASP.NET Core 和 MongoDB 建立 Web APIASP.NETMongoDBWebAPI
- ASP.NET Core ----ASP.NET Core中使用Code FirstASP.NET
- ASP.NET 6.0 Core 遷移 ASP.NET Core 7.0ASP.NET
- 【asp.net core 系列】 1 帶你瞭解一下asp.net coreASP.NET
- 【asp.net core 系列】14 .net core 中的IOCASP.NET
- ASP.NET Core Web API 流式返回,逐字顯示ASP.NETWebAPI
- VS2022-建立 ASP.NET Core Web 應用ASP.NETWeb
- 小白開學Asp.Net Core 《十》ASP.NET
- 小白開學Asp.Net Core 《九》ASP.NET
- 小白開學Asp.Net Core 《八》ASP.NET
- 小白開學Asp.Net Core 《四》ASP.NET
- 小白開學Asp.Net Core 《六》ASP.NET
- 針對ASP.NET Core Web API的先進架構ASP.NETWebAPI架構
- ASP.NET Core - 依賴注入(一)ASP.NET依賴注入
- 翻譯 - ASP.NET Core 基本知識 - Web 主機 (Web Host)ASP.NETWeb
- 從0到1手把手教你ASP.NET Core Web API專案配置介面文件Swagger(一)ASP.NETWebAPISwagger
- ASP.NET Core系列(二):建立第一個.Net Core 專案ASP.NET
- ASP.NET Core 奇技淫巧之介面代理轉發ASP.NET
- ASP.NET Core 實戰:使用 ASP.NET Core Web API 和 Vue.js,搭建前後端分離框架ASP.NETWebAPIVue.js後端框架
- 你所不知道的ASP.NET Core進階系列(三)ASP.NET
- 在ASP.NET Core中用HttpClient(六)——ASP.NET Core中使用HttpClientFactoryASP.NETHTTPclient
- Web SSH 的原理與在 ASP.NET Core SignalR 中的實現WebASP.NETSignalR
- ASP.NET Core 中介軟體(Middleware)(一)ASP.NET