您的位置:首页 > 编程语言 > ASP

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

2016-05-29 07:16 976 查看
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/



成功运行。
这里我们还可以对这个中间件进行进一步改进,增加更多的功能,如限制访问等。
原文地址:http://www.cnblogs.com/linezero/p/5529767.html
.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: