小白開學Asp.Net Core 《七》


小白開學Asp.Net Core 《七》

                           — — 探究中間件(MiddleWare)

1、何為中間件?

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

  • 選擇是否將請求傳遞給管道中的下一個組件
  • 可以在調用管道中的下一個組件之前和之后執行工作。

2、中間件的本質

 在.Net Core 中,中間件的本質就是一個Func的委托,其中RequestDelegate的本質也是一個委托(常常聽人說,要想進階到高級開發,必須要搞清楚委托。看來不得不搞懂委托了,本文默認您已搞懂了?如果沒搞懂怎么辦呢?不要緊,抽時間搞懂就行了),讓我們來看看它的定義(證明我沒在吹牛)

  

      再來看看 RequestDelegate

      

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

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

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

這里得上一張經典的圖配合上一句真理來理解就不那么難了。

  

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

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

           

 這次我把這個家伙的定義到截到圖里,我們嘗試着翻譯下:A function that can process an HTTP request. 我將它翻譯為:一個能夠處理HTTP請求的 function(函數、方法)。是不是大家突然間知道了,原來是這個家伙讓它們與HTTP關聯在一起的(產生了戀情)。

 好,如果你不信的話就讓我們來看看 HttpContext 這個家伙。為什么要看這個家伙呢,因為它是 RequestDelegate 這個委托 接受的參數。

  

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

 

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

3、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

 

4、總結

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

  2)、所有的代碼截圖都是 IApplicationBuilder F12后看到的

5、說明

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

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM