ASP.NET Core 中间件

DotNetCore实战

共 3300字,需浏览 7分钟

 · 2020-09-04

转自:梦里小探花
cnblogs.com/aoximin/p/13576479.html

前言


对中间件的一个概况,在《重新整理.net core 计1400篇》系列后面会深入。


正文


什么是中间件呢?


其实中间件这个概念来源于分布式,当然这是一个狭隘的概念了,现在中间件概念就非常广泛了。



官网给出了这样一张图,这张图认为从请求到响应过程中间都是中间件,包括我们认为的路由。


看一段node代码:


var http = require("http");
http.createServer(function(req,res){
res.writeHead(200,{"Content-type":"text/blain"});
res.write("Hello NodeJs");
res.end();
}).listen(8888);


没有学过node 也是ok的,从字面意思就是创建了一个http服务,然后端口是8888。

createServer 可以传入一个方法,中间有两个参数,一个参数是req,另一个参数就是res。


其实就是这么回事,我们写的就是这个这个方法里面的代码,至于,你想拿到req的什么参数,或者给res写入什么信息,这些都是中间件的范畴。


那么问题来了,问什么叫做中间件呢?从语文的层面上理解,那就是分开的,一件一件的。


把这件要执行的这些封装成一个一个模块,那么这些模块,这些可以通过调用next执行下一个模块,同样,如果不调用,那么中间件模块就会中断,因为有时候真的需要中断,比如说权限中间件,


检查到权限不符合直接返回让其跳转到权限页面,剩下的模块也用不到。


  • 用 Use 将多个请求委托链接在一起。next 参数表示管道中的下一个委托。可通过不调用 next 参数使管道短路。


  • 当委托不将请求传递给下一个委托时,它被称为“让请求管道短路”。通常需要短路,因为这样可以避免不必要的工作。


下图为ASP.NET Core中默认的中间件顺序,当然可以自己修改,但是这是一种推荐做法。



挺合理的一个东西,一开始就填入了异常处理机制。


然后是强制https 转换->重定向->静态资源文件->路由->是否跨域->认证->授权->我们自己自定义需求的。


因为这个endpoint 是不建议我们修改的,当然我们可以修改源码中,毕竟开源了,but not must。


官网中同样给了我们这个endpoint 做了什么,其实就是官方自己封装了一些中间件。



当然我们也可以进行对endpoint自我的调整,因为可能使用不同的模板引擎:


app.UseEndpoints(endpoints =>
{
endpoints.MapRazorPages();
endpoints.MapControllerRoute(
name: "default",
pattern: "{controller=Home}/{action=Index}/{id?}");
});


从上面得到一个推荐的中间件注册来看,认证和授权在静态文件之后,那么我们知道我们的资源时需要授权来保护的。


那么如何保护静态资源呢?这后面会有专门的一章实践一下,看下是什么原理。


好的,那么看一下我们如何自定义中间件吧,也就是实践一下下面这种图。



Middleware1


public class Middleware1
{
public readonly RequestDelegate _next;
public Middleware1(RequestDelegate next)
{
_next = next;
}
public async Task Invoke(HttpContext context)
{
Console.WriteLine("Middleware1");
await _next(context);
await context.Response.WriteAsync("Middleware1");
}
}



public class Middleware2
{
public readonly RequestDelegate _next;
public Middleware2(RequestDelegate next)
{
_next = next;
}
public async Task Invoke(HttpContext context)
{
Console.WriteLine("Middleware2");
await _next(context);
await context.Response.WriteAsync("Middleware2");
}
}


Middleware3


public class Middleware3
{
public readonly RequestDelegate _next;
public Middleware3(RequestDelegate next)
{
_next = next;
}
public async Task Invoke(HttpContext context)
{
Console.WriteLine("Middleware3");
await _next(context);
await context.Response.WriteAsync("Middleware3");
}
}


扩展方法


public static class Middleware1MiddlewareExtensions
{
public static IApplicationBuilder UserMiddleware1(this IApplicationBuilder builder)
{
return builder.UseMiddleware();
}
public static IApplicationBuilder UserMiddleware2(this IApplicationBuilder builder)
{
return builder.UseMiddleware();
}
public static IApplicationBuilder UserMiddleware3(this IApplicationBuilder builder)
{
return builder.UseMiddleware();
}
}


加入中间件队列


app.UserMiddleware1();
app.UserMiddleware2();
app.UserMiddleware3();


request 顺序



这其实就是一种职责链模式,每个中间件确定是否该需求是否要下一级处理,同样会产生一个处理回调。

往期精彩回顾




【推荐】.NET Core开发实战视频课程 ★★★

.NET Core实战项目之CMS 第一章 入门篇-开篇及总体规划

【.NET Core微服务实战-统一身份认证】开篇及目录索引

Redis基本使用及百亿数据量中的使用技巧分享(附视频地址及观看指南)

.NET Core中的一个接口多种实现的依赖注入与动态选择看这篇就够了

10个小技巧助您写出高性能的ASP.NET Core代码

用abp vNext快速开发Quartz.NET定时任务管理界面

在ASP.NET Core中创建基于Quartz.NET托管服务轻松实现作业调度

现身说法:实际业务出发分析百亿数据量下的多表查询优化

关于C#异步编程你应该了解的几点建议

C#异步编程看这篇就够了

给我好看

您看此文用

  · 

秒,转发只需1秒呦~

好看你就

点点


浏览 31
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报