本篇内容介绍了“ASP.NET Core怎么开发中间件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
开发中间件(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/
“ASP.NET Core怎么开发中间件”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注天达云网站,小编将为大家输出更多高质量的实用文章!