ASP.NET Core 開發-中間件(Middleware)

ASP.NET Core開發,開發並使用中間件(Middleware)。html

中間件是被組裝成一個應用程序管道來處理請求和響應的軟件組件。git

每一個組件選擇是否傳遞給管道中的下一個組件的請求,並能以前和下一組分在管道中調用以後執行特定操做。github

具體如圖:app

 

開發中間件(Middleware)

今天咱們來實現一個記錄ip 的中間件。asp.net

1.新建一個asp.net core項目,選擇空的模板。async

而後爲項目添加一個 Microsoft.Extensions.Logging.Consolepost

NuGet 命令行 ,請使用官方源。ui

Install-Package Microsoft.Extensions.Logging.Console -Prethis

2.新建一個類: RequestIPMiddleware.csspa

複製代碼
    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
標籤:  ASP.NET Core
相關文章
相關標籤/搜索