• ASPNET CORE初探


    ASP.NET Core 开发-中间件(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/

    成功运行。

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

    如果你觉得本文对你有帮助,请点击“推荐”,谢谢。

    .NET Core 跨平台交流群: 550897034 .NET Core跨平台 博客示例代码:GitHub
  • 相关阅读:
    SORT ORDER BY STOPKEY
    javaScript 数值型和字符串型之间的转换
    Caused by: org.apache.ibatis.type.TypeException: Could not resolve type alias 'Student'
    Caused by: java.sql.SQLException: Field 'stu_id' doesn't have a default value
    Result Maps collection does not contain value for StudentMapper.StudentMap
    集群维护
    logstash 调用exec
    logstash zabbix插件
    logstash 调用脚本告警
    Caused by: java.lang.NoSuchMethodException: com.you.entity.sys.Param.()
  • 原文地址:https://www.cnblogs.com/liangxiaofeng/p/5806351.html
Copyright © 2020-2023  润新知