小白開學Asp.Net Core 《七》

小白開學Asp.Net Core 《七》

                           — — 探究中間件(MiddleWare)

一、何爲中間件?

  中間件是組裝到應用程序管道中以處理請求和響應的傢伙,管道中的每一個組件都要知足如下兩個條件app

  • 選擇是否將請求傳遞給管道中的下一個組件
  • 能夠在調用管道中的下一個組件以前和以後執行工做。

二、中間件的本質

 在.Net Core 中,中間件的本質就是一個Func的委託,其中RequestDelegate的本質也是一個委託(經常聽人說,要想進階到高級開發,必需要搞清楚委託。看來不得不搞懂委託了,本文默認您已搞懂了?若是沒搞懂怎麼辦呢?沒關係,抽時間搞懂就好了),讓咱們來看看它的定義(證實我沒在吹牛)async

  

      再來看看 RequestDelegate函數

      

    接下來我嘗試着解釋下Func這個委託。咱們都知道 Func 這個 內置的委託學習

     (我只截了與本文相關的一張圖)ui

 經過Func 這個截圖的定義來看,它接受一個 T  返回一個 TResult ,結合咱們前面說的中間件來講,它接受一個RequestDelegate,返回一個RequestDelegate。也就是說,每個中間件Func的傳入參數RequestDelegate是下一個中間件的返回值,同時每個中間件Func的返回值是前一箇中間件的傳入參數。這樣就構成了一串中間件鏈表,每當一個請求過來,都會按照中間件的註冊順序依次執行RequestDelegate中的內容,這就構成了ASP.NET Core中的請求管道。(好好理解這句話,這是真理呀,開個玩笑,這是我本人這麼認爲的。)spa

這裏得上一張經典的圖配合上一句真理來理解就不那麼難了。翻譯

  

  好,咱們如今知道了Http請求處理管理是由多個Middleware組成的。可咱們上面從沒提到Http相關的信息,如今讓咱們看看它們是如何發生戀愛(產生關係的)?3d

  仔細看了前文的話,你們應該注意到RequestDelegate的定義(仔細回想下),哎 估計大家都想起來了,對仍是上圖咱們再學習下     code

           

 此次我把這個傢伙的定義到截到圖裏,咱們嘗試着翻譯下:A function that can process an HTTP request. 我將它翻譯爲:一個可以處理HTTP請求的 function(函數、方法)。是否是你們忽然間知道了,原來是這個傢伙讓它們與HTTP關聯在一塊兒的(產生了戀情)。中間件

 好,若是你不信的話就讓咱們來看看 HttpContext 這個傢伙。爲何要看這個傢伙呢,由於它是 RequestDelegate 這個委託 接受的參數。

  

    好了,這裏不得不相信,.Net Core 的 Http 請求處理管道是由多個Middleware 組成的,而且 Middleware 與 Http 請求上下文 僅僅的關聯在一塊兒。

 

  使用Use、Run和Map 配置HTTP管道。

三、Use、Run和Map

  您可使用Use、Run和Map 來配置HTTP管道,但各方法針對構建的中間件做用不一樣.

  Use:Use[Middleware]中間件負責調用管道中的下一個中間件,也可以使管道短路(即不調用 next 請求委託)。

  Run:Run[Middleware]是一種約定,一些中間件組件可能會公開在管道末端運行的Run[Middleware]方法。

  Map: Map擴展用做約定來建立管道分支, Map*建立請求管道分支是基於給定請求路徑的匹配項。

public class Startup
{
    public void Configure(IApplicationBuilder app)
    {
        app.Use(async (context, next) =>
        {
            // Do work that doesn't write to the Response.
            await next.Invoke();
            // Do logging or other work that doesn't write to the Response.
        });

        app.Run(async context =>
        {
            await context.Response.WriteAsync("Hello from 2nd delegate.");
        });
    }
}

Use將多個請求委託連接在一塊兒,next 參數表示管道中的下一個委託,可經過不 調用 next 參數使管道短路。 一般可在下一個委託先後執行操做。

當委託不將請求傳遞給下一個委託時,它被稱爲「讓請求管道短路」 。 一般須要短路,由於這樣能夠避免沒必要要的工做。

 Run委託終止管道。意思就是說,使用的Run 委託後,Run 下面的全部方法將不會被執行。

public class Startup
{
    private static void HandleMap1(IApplicationBuilder app)
    {
        app.Run(async context =>
        {
            await context.Response.WriteAsync("Map  1");
        });
    }

    private static void HandleMap2(IApplicationBuilder app)
    {
        app.Run(async context =>
        {
            await context.Response.WriteAsync("Map  2");
        });
    }

    public void Configure(IApplicationBuilder app)
    {
        app.Map("/map1", HandleMap1);

        app.Map("/map2", HandleMap2);

        app.Run(async context =>
        {
            await context.Response.WriteAsync("Hello from End Map delegate.");
        });
    }
}

執行與響應以下:

請求 響應
localhost:5000
Hello from End Map delegate.

localhost:5000/map1

Map  1

localhost:5000/map2

Map  2

 

四、總結

  1)、中間件(Middleware)是由IApplicationBuilder來構建的

  2)、全部的代碼截圖都是 IApplicationBuilder F12後看到的

五、說明

  參考文章:https://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/middleware/?view=aspnetcore-3.0

  若是本文有描述不對的地方或者產生誤導的地方,請及時反饋。

相關文章
相關標籤/搜索