DOTNET Core MVC(二)路由初探

来源:https://www.cnblogs.com/xtt321/archive/2020/02/21/12340001.html

擱置了幾天,工作忙的一塌糊塗,今天終於抽空來繼續看看MVC的知識。先來看看MVC的路由是如何處理的。以下為替代的路由: app.UseEndpoints(endpoints => { endpoints.MapControllerRoute( name: "default", pattern: "{ ...


擱置了幾天,工作忙的一塌糊塗,今天終於抽空來繼續看看MVC的知識。先來看看MVC的路由是如何處理的。以下為替代的路由:

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

通過Configure方法在運行時,以委托的形式註冊。

UseEndpoints:將中間件添加到的IApplicationBuilder再調用該方法時,需要先調用UseRouting。

public static IApplicationBuilder UseRouting(this IApplicationBuilder builder)
{
    if (builder == null)
    {
        throw new ArgumentNullException(nameof(builder));
    }
    VerifyRoutingServicesAreRegistered(builder);//校驗是否載入完成
    var endpointRouteBuilder = new DefaultEndpointRouteBuilder(builder);
    builder.Properties[EndpointRouteBuilder] = endpointRouteBuilder;
    return builder.UseMiddleware<EndpointRoutingMiddleware>(endpointRouteBuilder);
}

將Microsoft.AspNetCore.Routing.EndpointRoutingMiddleware中間件添加到指定的IApplicationBuilder中。

private static void VerifyRoutingServicesAreRegistered(IApplicationBuilder app)
{
    // Verify if AddRouting was done before calling UseEndpointRouting/UseEndpoint
    // We use the RoutingMarkerService to make sure if all the services were added.
    if (app.ApplicationServices.GetService(typeof(RoutingMarkerService)) == null)
    {
        throw new InvalidOperationException(Resources.FormatUnableToFindServices(
            nameof(IServiceCollection),
            nameof(RoutingServiceCollectionExtensions.AddRouting),
            "ConfigureServices(...)"));
    }
public static IApplicationBuilder UseEndpoints(this IApplicationBuilder builder, Action<IEndpointRouteBuilder> configure)
{
    if (builder == null)
    {
        throw new ArgumentNullException(nameof(builder));
    }
    if (configure == null)
    {
        throw new ArgumentNullException(nameof(configure));
    }
    VerifyRoutingServicesAreRegistered(builder);
    VerifyEndpointRoutingMiddlewareIsRegistered(builder, out var endpointRouteBuilder);
    configure(endpointRouteBuilder);
    // Yes, this mutates an IOptions. We're registering data sources in a global collection which
    // can be used for discovery of endpoints or URL generation.
    //
    // Each middleware gets its own collection of data sources, and all of those data sources also
    // get added to a global collection.
    var routeOptions = builder.ApplicationServices.GetRequiredService<IOptions<RouteOptions>>();
    foreach (var dataSource in endpointRouteBuilder.DataSources)
    {
        routeOptions.Value.EndpointDataSources.Add(dataSource);
    }
    return builder.UseMiddleware<EndpointMiddleware>();
}

ASP.NET Core 3使用完善的終結點路由,通常可以對應用程式內部的路由提供更多控制。端點路由分為兩個單獨的步驟:

在第一步中,再次匹配所請求的路由和配置的路由,找出以訪問正在的路由。在最後一步中,對確定的路由進行評估,並調用相應的中間件。

兩個步驟獨立,允許其他中間件在這些點之間起作用。允許中間件利用來自一個子的端點路由信息來處理授權,而不必執行實際的處理程式。

app.UseRouting()將註冊運行邏輯路由路由的中間件。

app.UseEndpoints()將執行該路由。

MapControllerRoute添加端點控制器操作的IEndpointRouteBuilder 並指定與路由給定namepattern,  defaultsconstraints,和dataTokens

其他:

MapController將添加到屬性路由的控制器支持。

MapController將添加到該屬性路由的控制器支持。

MapControllerRoute 添加控制器的常規路由

原創。轉載請註明出處。

啰嗦一堆,就說了兩個方法,下一篇接著說路由的用法〜

 


您的分享是我們最大的動力!

更多相關文章
  • python3-cookbook中每個小節以問題、解決方案和討論三個部分探討了Python3在某類問題中的最優解決方式,或者說是探討Python3本身的數據結構、函數、類等特性在某類問題上如何更好地使用。這本書對於加深Python3的使用和提升Python編程能力的都有顯著幫助,特別是對怎麼提高Py ...
  • 如何定義python源文件的文件編碼 如果想要定義文件代碼的編碼,一個特殊的註釋應該放到源文件的第一或第二行,例如: # coding=<encoding name> 或 使用一種大多數編輯器都能識別的方式 # -*- coding: <encoding name> -*- 或 # vim: set ...
  • 概述 logging翻譯為日誌記錄 那問題是什麼是日誌? 日誌實際上是日記的一種,用於記錄某個時間點發生了什麼事情,比如大學老師的教學日誌,工作日誌等 為什麼要記錄日誌? 在實際生活中記錄日誌主要為了日後複查, 比如某個大學老師每天記錄自己講的什麼內容,後面有學生某科成績優異獲獎了,校長想要獎勵對應 ...
  • 設:我們有一個coreSize=10,maxSize=20,keepAliveTime=60s,queue=40 1、池初始化時裡面沒有任何線程。 2、當有一個任務提交到池就創建第一個線程。 3、若繼續提交任務,有空閑線程就調撥空閑線程來處理任務?若沒有線程空閑則再新建一個線程來處理,如此直到cor ...
  • 0、背景:在由於不想在小項目中引入SpringSecurity這種重量級安全框架,我自定義了一個LoginFilter來處理認證+授權邏輯。對於認證或授權失敗的情況,最初是在filter中拋出異常,並攜帶401狀態碼,然後利用Spring的ControllerAdvice全局捕獲這些異常並轉換後返回 ...
  • 1. Stream介面,它 直接負責 位元組流的傳輸。 2. Reader/Writer介面,它本身 不能讀直接讀寫數據 ,而是以Stream介面為內部核心,在外圍裝飾增強,負責字元流的讀寫。字元和位元組的轉換過程必須指定 字元編碼 方式。 3. 為了提高Reader/Writer介面的效率,又在外圍裝 ...
  • 0、前言 用mybatis,那麼分頁必不可少,基本都是用PageHelper這個分頁插件,好用方便; 1、實現 1.1、添加依賴: <!-- 3、集成 mybatis pagehelper--> <dependency> <groupId>com.github.pagehelper</groupId ...
  • 多用www.bing.com國際版解決代碼報錯 代碼運行的時候,報異常,國內的搜索引擎一搜, 浮誇的廣告太多,解決方案准確性不足, 盜版又很嚴重(導致一錯皆錯),方案未及時更新等詬病。 www.bing.com國際版可以關聯到: (1). 外國官網,可以獲得官方的解決方案。 (2). stackov ...
一周排行
  • 上一篇文章(https://www.cnblogs.com/meowv/p/12943699.html)完成了項目的全局異常處理和日誌記錄。 在日誌記錄中使用的靜態方法有人指出寫法不是很優雅,遂優化一下上一篇中日誌記錄的方法,具體操作如下: 在.ToolKits層中新建擴展方法Log4NetExte ...
  • 先安裝幾個包 獲取地址如下https://www.nuget.org/packages/QRCoder/https://www.nuget.org/packages/SixLabors.Fonts/https://www.nuget.org/packages/SixLabors.ImageSharp ...
  • 0. 前言 前一篇我們詳細的介紹了SqlSugar的增刪改查,那些已經滿足我們在日常工程開發中的使用了。但是還有一點點在開發中並不常用,但是卻非常有用的方法。接下來讓我們一起來看看還有哪些有意思的內容。 1. 不同尋常的查詢 之前介紹了針對單個表的查詢,同樣也是相對簡單的查詢模式。雖然開發完全夠用, ...
  • 最新.net core 圖片合併生成二維碼合成圖片 圖片添加文字 先安裝幾個包 獲取地址如下 https://www.nuget.org/packages/QRCoder/ https://www.nuget.org/packages/SixLabors.Fonts/ https://www.nug ...
  • 前言 之前我寫過一篇關於 Blazor WebAssembly 的文章瀏覽器中的 .Net Core —— Blazor WebAssembly 初體驗,如今已經更新到 RC-1,與預覽版有著較大的差異,為此補充這篇文章。 正文 與預覽版的主要差異 1、這次的候選版修改了大部分包名和命名空間,因此無 ...
  • 藍牙設置相關界面,以下是通過C#方式打開的幾個方式,記錄一下 藍牙設置界面 1.控制面板命令bthprops.cpl 可以用控制面板 control+bthprops.cpl,也可以直接bthprops.cpl。更多的命令見:所有運行命令指令大全、CMD & CPL:快捷系統命令和控制面板命令 bt ...
  • 一:背景 1. 講故事 去年阿裡聚石塔上的所有isv簡訊通道全部對接阿裡通信,我們就做了對接改造,使用阿裡提供的.net sdk。 網址:https://help.aliyun.com/document_detail/114480.html 同事當時使用的是ons-.net v1.1.3版本,程式上 ...
  • 一.相關介紹 Dockerfile:關於Dockerfile的使用說明,我在文章《讓.NetCore程式跑在任何有docker的地方》中有說到,這裡不在贅述,需要的可以先看下,本文主要介紹Jenkinsfile結合dockerfile配合使用,自動構建.NetCore應用程式。 Jenkinsfil ...
  • 當用戶嚮應用程式發出請求時,伺服器將解析該請求,生成響應,然後將結果發送給客戶端。用戶可能會在伺服器處理請求的時候中止請求。就比如說用戶跳轉到另一個頁面中獲取說關閉頁面。在這種情況下,我們希望停止所有正在進行的工作,以浪費不必要的資源。例如我們可能要取消SQL請求、http調用請求、CPU密集型操作 ...
  • 在.NET中,我們可以通過Task.WhenAll用來等待多個任務。任務完成之後,我們可以使用await等待他們來獲取結果。 Task<int> task1 = Task.Run(() => 1); Task<string> task2 = Task.Run(() => "hello"); awai ...