• 中间件(Middleware)


    中间件(Middleware)

    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/

    成功运行。

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

  • 相关阅读:
    排查和解决线上SQL和连接和hung住等问题
    动态模型中嵌入静态模型实践
    敏捷 ? DevOps ?
    Redis stream性能测试实践【Java版】
    性能测试中的随机数性能问题探索
    jdbc自带MySQL连接池实践
    延迟队列DelayQueue性能测试
    Java的标识符(命名规范)
    C# 数据类型与类型转换
    C#初识
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/5538617.html
Copyright © 2020-2023  润新知