zoukankan      html  css  js  c++  java
  • 中间件(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/

    成功运行。

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

  • 相关阅读:
    python内置的魔术命令(builtin magic commands)
    绘制ROC曲线
    python with语句中的变量有作用域吗?
    Visual Studio上编译ncnn
    loss函数学习笔记
    Install zeal on ubuntu16.04
    cmake方式使用vlfeat
    整理读研期间用过、改进过、写过的代码
    ubuntu下使用matplotlib绘图无法显示中文label
    error: each element of 'ext_modules' option must be an Extension instance or 2-tuple
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/5538617.html
Copyright © 2011-2022 走看看