ASP.NETコア開発、ミドルウェアの開発と利用(ミドルウェア)。
ミドルウェアは、ソフトウェア・アプリケーション・コンポーネントの要求と応答を処理するためのパイプラインに組み込まれます。
各成分は、導管内の次のコンポーネントを選択するかどうかを要求し、呼び出し後と前次のコンポーネントにパイプラインの特定の操作を実行するために送信されます。
具体的には、図示のように:
ミドルウェアの開発(ミドルウェア)
今日は、レコードのIPミドルウェアを達成しました。
1.新しいasp.netコアプロジェクトを作成し、空のテンプレートを選択します。
そして、Microsoft.Extensions.Logging.Consoleプロジェクトを追加
NuGetコマンドラインは、公式のソースを使用しています。
インストール・パッケージMicrosoft.Extensions.Logging.Console -pre
2.新しいクラスを作成します。RequestIPMiddleware.csを
public class RequestIPMiddleware { private readonly RequestDelegate _next; private readonly ILogger _logger; public RequestIPMiddleware(RequestDelegate next, ILoggerFactory loggerFactory) { _next = next; _logger = loggerFactory.CreateLogger<RequestIPMiddleware>(); } public async Task Invoke(HttpContext context) { _logger.LogInformation("User IP: " + context.Connection.RemoteIpAddress.ToString()); await _next.Invoke(context); } }
3.再新建一个:RequestIPExtensions.cs
public static class RequestIPExtensions { public static IApplicationBuilder UseRequestIP(this IApplicationBuilder builder) { return builder.UseMiddleware<RequestIPMiddleware>(); } }
这样我们就编写好了一个中间件。
使用中间件(Middleware)
1.使用
在 Startup.cs 添加 app.UseRequestIP()
public void Configure(IApplicationBuilder app, ILoggerFactory loggerfactory) { loggerfactory.AddConsole(minLevel: LogLevel.Information); app.UseRequestIP();//使用中间件 app.Run(async (context) => { await context.Response.WriteAsync("Hello World!"); }); }
然后运行程序,我选择使用Kestrel 。
访问:http://localhost:5000/
成功运行。
这里我们还可以对这个中间件进行进一步改进,增加更多的功能,如限制访问等。
如果你觉得本文对你有帮助,请点击“推荐”,谢谢。
ASP.NET Core开发,开发并使用中间件(Middleware)。
中间件是被组装成一个应用程序管道来处理请求和响应的软件组件。
每个组件选择是否传递给管道中的下一个组件的请求,并能之前和下一组分在管道中调用之后执行特定操作。
具体如图:
开发中间件(Middleware)
今天我们来实现一个记录ip 的中间件。
1.新建一个asp.net core项目,选择空的模板。
然后为项目添加一个 Microsoft.Extensions.Logging.Console
NuGet 命令行 ,请使用官方源。
Install-Package Microsoft.Extensions.Logging.Console -Pre
2.新建一个类: RequestIPMiddleware.cs
public class RequestIPMiddleware { private readonly RequestDelegate _next; private readonly ILogger _logger; public RequestIPMiddleware(RequestDelegate next, ILoggerFactory loggerFactory) { _next = next; _logger = loggerFactory.CreateLogger<RequestIPMiddleware>(); } public async Task Invoke(HttpContext context) { _logger.LogInformation("User IP: " + context.Connection.RemoteIpAddress.ToString()); await _next.Invoke(context); } }
3.再新建一个:RequestIPExtensions.cs
public static class RequestIPExtensions { public static IApplicationBuilder UseRequestIP(this IApplicationBuilder builder) { return builder.UseMiddleware<RequestIPMiddleware>(); } }
这样我们就编写好了一个中间件。
使用中间件(Middleware)
1.使用
在 Startup.cs 添加 app.UseRequestIP()
public void Configure(IApplicationBuilder app, ILoggerFactory loggerfactory) { loggerfactory.AddConsole(minLevel: LogLevel.Information); app.UseRequestIP();//使用中间件 app.Run(async (context) => { await context.Response.WriteAsync("Hello World!"); }); }
然后运行程序,我选择使用Kestrel 。
访问:http://localhost:5000/
成功运行。
这里我们还可以对这个中间件进行进一步改进,增加更多的功能,如限制访问等。
如果你觉得本文对你有帮助,请点击“推荐”,谢谢。