ASP.NET Core 开发-中间件(Middleware)

ASP.NET Core开发,开发并使用中间件(Middleware)。app

中间件是被组装成一个应用程序管道来处理请求和响应的软件组件。asp.net

每一个组件选择是否传递给管道中的下一个组件的请求,并能以前和下一组分在管道中调用以后执行特定操做。async

具体如图:ui

 

开发中间件(Middleware)

今天咱们来实现一个记录ip 的中间件。this

1.新建一个asp.net core项目,选择空的模板。spa

而后为项目添加一个 Microsoft.Extensions.Logging.Console.net

NuGet 命令行 ,请使用官方源。命令行

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

2.新建一个类: RequestIPMiddleware.csorm

    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/

成功运行。

这里咱们还能够对这个中间件进行进一步改进,增长更多的功能,如限制访问等。

 

若是你以为本文对你有帮助,请点击“推荐”,谢谢。

相关文章
相关标签/搜索