不少刚学习.net core朋侪对中间件的概念不停分不清晰,到底StartUp下的Configure方法是在做什么?
- public void Configure(IApplicationBuilder app, IHostingEnvironment env)
- {
- if (env.IsDevelopment())
- {
- app.UseDeveloperExceptionPage();
- }
- app.UseMvc();
- }
复制代码
各人都说每个request进来都会对Configure方法中的中间件实验一遍,但通过调试发现,只有步伐在启动时才会实验这段代码,事后的每次哀求并不会进入
下面给各人简单表明一下:
假设有3个方法A B C,都有本身的业务逻辑,且参数范例与返回值范例雷同
- public Task MethodA(HttpContext context);
- public Task MethodB(HttpContext context);
- public Task MethodC(HttpContext context);
复制代码
这个时间假设我通过某种本领将C方法放进B方法变成方法BC,类似:
- public Task MethodBC(HttpContext context)
- {
- //方法B原先逻辑
- return MethodC(context);
- }
复制代码
同理将方法BC放进方法A变成方法ABC:
- public Task MethodABC(HttpContext context)
- {
- //方法A原先逻辑
- return MethodBC(context);
- }
- 睁开后:
- public Task MethodABC(HttpContext context)
- {
- //方法A原先逻辑
- //方法B原先逻辑
-
- return MethodC(context);
- }
复制代码
将本来互不干执的3个方法揉进一个方法中,当服务器吸收到哀求时,封装好上下文丢进这个聚合方法
换个思绪,感觉观察者模式会不会更简单些,IServer中写个事故,有必要往内里注册就好了
那怎么才可以将方法当个参数一样使用呢,自然是委托,下面官方的声明:
中间件中最基础的组件,以HttpContext为参数,Task作为返回值
delegate Task RequestDelegate(HttpContext context);
中间件的根本实现原理:
- public RequestDelegate Use(RequestDelegate @delegate)
- {
- return (context)=>
- {
- //一些逻辑
- return @delegate.Invoke(context);
- };
- }
复制代码
细细一想,是不是就是在@delegate前面加了一些逻辑后重新天生一个RequestDelegate返回
g |