asp.net mvc core管道及攔截器的理解

 更新時間:2020-06-14 00:02:00   作者:佚名   我要評論(0)

今天來看一下asp.net core的執行管道。先看下官方說明:

從上圖可以拋光,asp.net core的執行順序是,當收到一個請求后,request請求會先經過已注冊的中間件,然后

今天來看一下asp.net core的執行管道。先看下官方說明:

 從上圖可以拋光,asp.net core的執行順序是,當收到一個請求后,request請求會先經過已注冊的中間件,然后會進入到mvc的攔截器管道:

進入mvc管道后,根據以上順序執行過濾校正。

OK,根據以上說明下面我們新建一個MVC的演示,將執行方式切換為控臺運行:

// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
 services.AddControllersWithViews(config=> 
 {
  Console.WriteLine("execute C");
  //config.Filters.Add(new AsyncAuthorizationFilter());
  config.Filters.Add(new AuthorizationFilter());
  config.Filters.Add(new ResourceFilter());
  //config.Filters.Add(new AsyncResourceFilter());
  config.Filters.Add(new ActionFilter());
  //config.Filters.Add(new AsyncActionFilter());
  config.Filters.Add(new ResultFilter());
  //config.Filters.Add(new AsyncResultFilter());
  config.Filters.Add(new ExceptionFilter());
  //config.Filters.Add(new AsyncExceptionFilter());
  Console.WriteLine("execute D");
 });
 services.AddSession(config=> {
  Console.WriteLine("execute E");
 });
}

// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
 if (env.IsDevelopment())
 {
  app.UseDeveloperExceptionPage();
 }
 else
 {
  app.UseExceptionHandler("/Home/Error");
 }
 app.UseStaticFiles();
 app.UseRouting();
 app.UseAuthorization();
 app.Use(async (context, next) =>
 {
  Console.WriteLine("execute F");
  await context.Response.WriteAsync("hello world");
  Console.WriteLine("execute G");
 });
 //app.UseSession();
 app.UseEndpoints(endpoints =>
 {
  Console.WriteLine("execute A");
  endpoints.MapControllerRoute(
   name: "default",
   pattern: "{controller=Home}/{action=Index}/{id?}");
  Console.WriteLine("execute B");
 });
}

執行結果:

不多做解釋,從從這里我們可以拋光符合官方說明文檔。

看完中間件執行順序,下面我們來了解下mvc攔截器的使用與執行順序。

根據mvc filter管道執行順序,我們分別來看下用法:

1)AuthorizationFilter:該攔截器是優先級最高的,當請求進入mvc后,首先會被AuthorizationFilter驗證是否有權限訪問,無權限則跳出。

同步用法:

public class AuthorizationFilter: IAuthorizationFilter
{
 public void OnAuthorization(AuthorizationFilterContext context)
 {
  context.HttpContext.Response.WriteAsync("authorization filter \r");
 }
}

異步用法:

public class AsyncAuthorizationFilter: IAsyncAuthorizationFilter
{
 public async Task OnAuthorizationAsync(AuthorizationFilterContext context)
 {
  await context.HttpContext.Response.WriteAsync($"async authorization filter in \r");
 }
}

2)ResourceFilter:該攔截器是作為第二道攔截器,

OnResourceExecuting在模型綁定之前運行代碼。OnResourceExecuted在管道的其余階段完成之后運行代碼。

同步用法:

public class ResourceFilter: IResourceFilter
{
 public void OnResourceExecuting(ResourceExecutingContext context)
 {
  context.HttpContext.Response.WriteAsync($"resource executing\r");
 }
 public void OnResourceExecuted(ResourceExecutedContext context)
 {
  context.HttpContext.Response.WriteAsync($"resource executed \r");
 }
}

異步用法:

public class AsyncResourceFilter: IAsyncResourceFilter
{
 public async Task OnResourceExecutionAsync(ResourceExecutingContext context, ResourceExecutionDelegate next)
 {
  await context.HttpContext.Response.WriteAsync($" async resource filter in. \r\n");
  await next();
  await context.HttpContext.Response.WriteAsync($"async resource filter out. \r\n");
 }
}

3)ActionFilter:在調用操作方法之前和之后立即運行代碼;可以更改傳遞到操作中的參數;可以更改從操作返回的結果。

同步用法:

public class ActionFilter: IActionFilter
{
 public void OnActionExecuting(ActionExecutingContext context)
 {
  context.HttpContext.Response.WriteAsync($"action executing \r");
 }

 public void OnActionExecuted(ActionExecutedContext context)
 {
  context.HttpContext.Response.WriteAsync($"action executed . \r");
 }
}

異步用法:

public async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
{
 await context.HttpContext.Response.WriteAsync($"async action execution in. \r\n");
 await next();
 await context.HttpContext.Response.WriteAsync($"async action execution out. \r\n");
}

4)OnException:在向響應正文寫入任何內容之前,對聲明處理的異常應用變量策略。

同步用法:

public class ExceptionFilter: IExceptionFilter
{
 public void OnException(ExceptionContext context)
 {
  context.HttpContext.Response.WriteAsync($"exception \r");
 }
}

異步用法:

public class AsyncExceptionFilter: IAsyncExceptionFilter
{
 public Task OnExceptionAsync(ExceptionContext context)
 {
  context.HttpContext.Response.WriteAsync($"exception async \r");
  return Task.CompletedTask;
 }
}

5)ResultFilter:在執行操作結果之前和之后立即運行代碼;僅當操作方法成功執行時,其才會運行。 可以設置格式化返回結果:

同步操作:

public class ResultFilter: IResultFilter
{
 public void OnResultExecuting(ResultExecutingContext context)
 {
  context.HttpContext.Response.WriteAsync($"result executing\r");
 }
 public void OnResultExecuted(ResultExecutedContext context)
 {
  context.HttpContext.Response.WriteAsync($"result executed \r");
 }
}

異步用法:

public class AsyncResultFilter: IAsyncResultFilter
{
 public async Task OnResultExecutionAsync(ResultExecutingContext context, ResultExecutionDelegate next)
 {
  await context.HttpContext.Response.WriteAsync($"result execution async in \r");
  await next();
  await context.HttpContext.Response.WriteAsync($"result execution async out. \r");
 }
}

注冊方式我們就是用分區注冊,已經在上面說明,不再多做表述,下面我們看下運行情況(頁面輸出):

 定義一個異常看下結果:

public IActionResult Privacy()
{
  throw new Exception("error");
}

ok,目標達成,不多說了,下次再看攔截器具體實現。

參考文檔:ASP.NET Core 中的篩選器

總結

到此這篇關于asp.net mvc core管道及攔截器的文章就介紹到這了,更多相關asp.net mvc core管道及攔截器內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

  • Asp.net請求處理之管道處理介紹
  • Asp.net Mvc 身份驗證、異常處理、權限驗證(攔截器)實現代碼
  • ASP.NET Core 3.0 gRPC攔截器的使用

相關文章

  • asp.net mvc core管道及攔截器的理解

    asp.net mvc core管道及攔截器的理解

    今天來看一下asp.net core的執行管道。先看下官方說明: 從上圖可以拋光,asp.net core的執行順序是,當收到一個請求后,request請求會先經過已注冊的中間件,然后
    2020-06-14
  • 聊一聊Asp.net過濾器Filter那一些事

    聊一聊Asp.net過濾器Filter那一些事

    最近在整理優化.net代碼時,發現幾個很不友好的處理現象:登錄判斷、權限認證、日志記錄、異常處理等通用操作,在項目中的action中到處都是。在代碼優化上,這一點是
    2020-06-14
  • xUnit 編寫 ASP.NET Core 單元測試的方法

    xUnit 編寫 ASP.NET Core 單元測試的方法

    還記得 .NET Framework 的 ASP.NET WebForm 嗎?那個年代如果要在 Web 層做單元測試簡直就是災難啊。.NET Core 吸取教訓,在設計上考慮到了可測試性,就連 ASP.NET
    2020-06-14
  • ASP.NET Core自定義中間件如何讀取Request.Body與Response.Body的內容詳解

    ASP.NET Core自定義中間件如何讀取Request.Body與Response.Body的內容詳解

    背景# 最近在徒手造輪子,編寫一個ASP.NET Core的日志監控器,其中用到了自定義中間件讀取Request.Body和Response.Body的內容,但是編寫過程,并不像想象中的一帆
    2020-06-14
  • ASP.NET Core MVC如何實現運行時動態定義Controller類型

    ASP.NET Core MVC如何實現運行時動態定義Controller類型

    昨天有個朋友在微信上問我一個問題:他希望通過動態腳本的形式實現對ASP.NET Core MVC應用的擴展,比如在程序運行過程中上傳一段C#腳本將其中定義的Controller類型注
    2020-06-14
  • 實例講解PHP表單

    實例講解PHP表單

    表單處理 GET vs. POST 1 GET 和 POST 都創建數組(例如,array( key => value, key2 => value2, key3 => value3, ...))。此數組包含鍵/值對,其中的鍵是表單控
    2020-06-10
  • keras多顯卡訓練方式

    keras多顯卡訓練方式

    使用keras進行訓練,默認使用單顯卡,即使設置了os.environ['CUDA_VISIBLE_DEVICES']為兩張顯卡,也只是占滿了顯存,再設置tf.GPUOptions(allow_growth=True)之后可
    2020-06-10
  • 淺談Python中的模塊

    淺談Python中的模塊

    模塊 為了編寫可維護的代碼,我們把很多函數分組,分別放到不同的文件里,這樣,每個文件包含的代碼就相對較少,很多編程語言都采用這種組織代碼的方式。在Pytho
    2020-06-10
  • 基于SQLAlchemy實現操作MySQL并執行原生sql語句

    基于SQLAlchemy實現操作MySQL并執行原生sql語句

    場景應用 老大我讓爬取內部網站獲取數據,插入到新建的表中,并每天進行爬取更新數據(后面做了定時任務)。然后根據該表統計每日的新增數量/更新數量進行制圖制
    2020-06-10
  • 什么是python類屬性

    什么是python類屬性

    首先我們來看一下屬性的定義 屬性的定義:python中的屬性其實是普通方法的衍生。 操作類屬性有三種方法: 1.使用@property裝飾器操作類屬性。 2.使用類或實例直接操
    2020-06-10

最新評論

买宝宝用品赚钱吗 福建快三推荐号码 股票的发行主体 青海快三跨度走势走势图 重庆时时最新开奖历史 河南快三今天开奖号码 线上股票配资选哪家 新三板股票 st股票推荐 贵州体育彩票11选5 内蒙古快三十大技巧 36选7中奖规则 江苏十一选五前三直结果 3d预测最准确网站 大赢家江西时时彩 河北十一选五 一定牛 上证指数股票