asp.net core 系列 7 Razor框架路由(上)

来源:https://www.cnblogs.com/MrHSR/archive/2019/01/14/10265458.html
-Advertisement-
Play Games

一.概述 在上二篇中,主要是介紹了asp.net core mvc中路由的使用,這篇繼續介紹路由在ASP.NET Core Razor中的使用。Razor Pages應該使用預設的傳統路由,從應用程式的Pages文件夾中提供命令資源。還可以使用其他約定來自定義 Razor Pages 路由行為。 在 ...


一.概述

  在上二篇中,主要是介紹了asp.net core mvc中路由的使用,這篇繼續介紹路由在ASP.NET Core Razor中的使用。Razor Pages應該使用預設的傳統路由,從應用程式的Pages文件夾中提供命令資源。還可以使用其他約定來自定義 Razor Pages 路由行為。

  在ASP.NET Core MVC 中是使用路由中間件來匹配傳入請求的 URL 並將它們映射到操作(action)。而ASP.NET Core  Razor使用頁面路由和應用模型提供程式約定,來控制 Razor 頁面應用中的頁面路由、發現和處理。

  使用AddRazorPagesOptions 擴展方法向 Startup 類中服務集合的 AddMvc 服務中添加和配置 Razor 頁面約定。

            services.AddMvc()
                .SetCompatibilityVersion(CompatibilityVersion.Version_2_2)
                .AddRazorPagesOptions(options=> {

                     //添加razor頁面路由和應用模型約定
                    //options.Conventions.Add();
                });

  在ASP.NET Core 的 Razor框架頁面中,路由和應用的約定有四大類。都需要實現IPageConvention介面。在MVC框架下路由需要實現IRouteBuilder介面。

 

  (1) 模型約定 Conventions.Add

    通過Conventions.Add添加的模型約定(Model conventions)。作用是:將路由模板和標頭(page header)添加到應用的頁面。模型約定有三種實現的介面IPageRouteModelConvention(路由模型約定)、IPageApplicationModelConvention(應用模型約定)、IPageHandlerModelConvention(處理程式模型約定)。

 

  (2)  頁面路由操作約定  Page route action conventions

    通過頁面路由操作約定。作用是:可以將路由模板添加到某個文件夾中的頁面以及單個頁面。AddFolderRouteModelConvention(文件夾路由模型約定)、AddPageRouteModelConvention(頁面路由模型約定)AddPageRoute(配置頁面路由)

 

  (3) 頁面模型操作約定 Page model action conventions

    通過頁面模型操作約定。作用是:可以將標頭添加到某個文件夾中的多個頁面,將標頭添加到單個頁面,以及配置篩選器工廠以將標頭添加到應用的頁面  

AddFolderApplicationModelConvention(文件夾應用模型約定) AddPageApplicationModelConvention(頁面應用模型約定) ConfigureFilter(配置篩選器)

 

  (4) 預設頁面應用模型提供程式 Default page app model provider

    用戶可以從預設模型提供程式繼承,以便為處理程式發現和處理提供自己的實現邏輯 。

二. 模型約定

  為IPageConvention添加委托,以添加應用於 Razor 頁面的模型約定。

 

  2.1  IPageRouteModelConvention

    將路由模型約定添加到所有頁面。使用約定創建IPageRouteModelConvention並將其添加到IPageConvention實例集合中,這些實例將在頁面路由模型構造過程中應用。下麵示例應用將 {globalTemplate?} 路由模板添加到應用中的所有頁面。

    /// <summary>
    /// 只在程式啟動時調用(每頁面路由對應執行一次apply)
    /// </summary>
    public class GlobalTemplatePageRouteModelConvention : IPageRouteModelConvention
    {
        ///<summary>
        ///運用到所有頁面路由模型中,制定頁面路由模板,比如訪問index頁。
        ///路由模板可以是/index 也可以是/index/{可選參數}
        ///</summary>
        ///<param name="model"></param>
        public void Apply(PageRouteModel model)
        {
            var selectorCount = model.Selectors.Count;
            for (var i = 0; i < selectorCount; i++)
            {
                var selector = model.Selectors[i];
                model.Selectors.Add(new SelectorModel
                {
                    AttributeRouteModel = new AttributeRouteModel
                    {
                        //執行路由順序
                        Order = 1,
                        //頁面路由模板
                        Template = AttributeRouteModel.CombineTemplates(selector.AttributeRouteModel.Template,"{globalTemplate?}")
                    }
                });

            }
        }
    }

    將 MVC 添加到Startup.ConfigureServices中的服務集合時,會添加 Razor 頁面選項,例如:添加上面的約定。

            services.AddMvc()
                    .AddRazorPagesOptions(options =>
                    {
                        options.Conventions.Add(new GlobalTemplatePageRouteModelConvention());
                    })
                    .SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

    在about頁綁定 @RouteData.Values["globalTemplate"]。如果在瀏覽器訪問: /about/globalRouteValue時,頁面顯示:route data for'globalTemplate'wasprovided:globalRouteValue

    在上面案例的路由模型約定的PageRouteModel實例中,在調試下查看about的路由規則生成如下:  model.Selectors[1].AttributeRouteModel.Template的值為:

    About/{globalTemplate?}

 

  2.2 IPageApplicationModelConvention

    將應用模型約定添加到所有頁面。使用約定創建IPageApplicationModelConvention並將其添加到IPageConvention實例集合中,這些實例將在頁面應用模型構造過程中應用

    為了演示此約定,示例應用包含了一個 AddHeaderAttribute 類。 類構造函數採用 name 字元串和 values 字元串數組。 將在其 OnResultExecuting 方法中使用這些值來設置響應標頭。使用 AddHeaderAttribute 類將標頭 GlobalHeader 添加到應用中的所有頁面。

    ///<summary>
    ///頁面載入時調用(每一個路由地址)
    ///</summary>
    public class GlobalHeaderPageApplicationModelConvention : IPageApplicationModelConvention
    {
        public void Apply(PageApplicationModel model)
        {
            model.Filters.Add(new AddHeaderAttribute(
            "GlobalHeader", new string[] { "Global Header Value" }));
        }
    }

    public class AddHeaderAttribute : ResultFilterAttribute
    {
        private readonly string _name;
        private readonly string[] _values;

        public AddHeaderAttribute(string name, string[] values)
        {
            _name = name;
            _values = values;
        }

        public override void OnResultExecuting(ResultExecutingContext context)
        {
            context.HttpContext.Response.Headers.Add(_name, _values);
            base.OnResultExecuting(context);
        }
    }
            services.AddMvc()
                    .AddRazorPagesOptions(options =>
                    {
                        options.Conventions.Add(new GlobalTemplatePageRouteModelConvention());
                        options.Conventions.Add(new GlobalHeaderPageApplicationModelConvention());
                    })
                    .SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

    在 /About 中請求示例的“關於”頁面,並檢查標頭以查看結果:

 

  2.3 IPageHandlerModelConvention

     將處理程式模型約定添加到的所有頁面。使用約定創建IPageHandlerModelConvention並將其添加到IPageConvention實例集合中,這些實例將在頁面處理程式模型構造過程中應用

    public class GlobalPageHandlerModelConvention : IPageHandlerModelConvention
    {
        //頁面載入時調用(每一個路由地址),在IPageApplicationModelConvention約定之後執行
        public void Apply(PageHandlerModel model)
        {
            //目前還不清楚能做什麼
        }
    }
            services.AddMvc()
                    .AddRazorPagesOptions(options =>
                    {
                        options.Conventions.Add(new GlobalTemplatePageRouteModelConvention());
                        options.Conventions.Add(new GlobalHeaderPageApplicationModelConvention());
                        options.Conventions.Add(new GlobalPageHandlerModelConvention());
                    })
                    .SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

    

三. 頁面路由操作約定

  預設路由模型提供程式派生自IPageRouteModelProvider,可調用旨在為頁面路由配置提供擴展點的約定。   

 

  3.1 AddFolderRouteModelConvention

     使用AddFolderRouteModelConvention創建並添加IPageRouteModelConvention,後者可以為指定文件夾下的所有頁面調用PageRouteModel上的操作。示例應用使用  

    AddFolderRouteModelConvention 將 {otherPagesTemplate?} 路由模板添加到 OtherPages 文件夾中的頁面:

                        options.Conventions.AddFolderRouteModelConvention("/OtherPages", model =>
                        {
                            //OtherPages文件夾下的頁面,都用此路由模板。
                            var selectorCount = model.Selectors.Count;
                            for (var i = 0; i < selectorCount; i++)
                            {
                                var selector = model.Selectors[i];
                                model.Selectors.Add(new SelectorModel
                                {
                                    AttributeRouteModel = new AttributeRouteModel
                                    {
                                        //用於處理路由匹配,指定路由處理順序。按順序處理的路由 (-1、 0、 1、 2、 … n)
                                        Order = 2,
                                        Template = AttributeRouteModel.CombineTemplates
                                        (selector.AttributeRouteModel.Template,"{otherPagesTemplate?}")
                                    }
                                });
                            }
                        });

  這裡將AttributeRouteModel的 Order 屬性設置為 2。在第一個路由數據值時(如:/page1/RouteDataValue,這裡的RouteDataValue就是第一個路由數據值),可以保證之前模板{globalTemplate?}分配到優先順序。

  當globalTemplate路由模板Order=1,otherPagesTemplate路由模板Order=2時。在瀏覽器輸入 :/OtherPages/Page1/RouteDataValue。路由值由globalTemplate模板取出。

    RouteData.Values["otherPagesTemplate"]
    null
    RouteData.Values["globalTemplate"]
    "RouteDataValue"

 

  3.2 AddPageRouteModelConvention

    使用AddPageRouteModelConvention創建並添加IPageRouteModelConvention,後者可以為具有指定名稱的頁面調用PageRouteModel上的操作。

    示例應用使用AddPageRouteModelConvention將 {aboutTemplate?} 路由模板添加到“About”頁面:

                        options.Conventions.AddPageRouteModelConvention("/About", model =>
                        {
                            //About頁面,用此路由模板。
                            var selectorCount = model.Selectors.Count;
                            for (var i = 0; i < selectorCount; i++)
                            {
                                var selector = model.Selectors[i];
                                model.Selectors.Add(new SelectorModel
                                {
                                    AttributeRouteModel = new AttributeRouteModel
                                    {
                                        Order = 2,
                                        Template = AttributeRouteModel.CombineTemplates
                                        (selector.AttributeRouteModel.Template, "{aboutTemplate?}")
                                    }
                                });
                            }
                        });

    這個功能就不在演示,功能與示例3.1相同,一個作用於文件夾下的所有pages頁面,一個作用於指定某個page頁面。重點關註三點:1是路由作用域,2是order路由順序,3是定義好Template路由規則。

    

  

 參考文獻

  官方資料:asp.net core routing

 


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

-Advertisement-
Play Games
更多相關文章
  • ADO.NET系列之Connection對象 ADO.NET系列之Command對象 ADO.NET系列之DataAdapter對象 ADO.NET系列之事務和調用存儲過程 前幾篇我們介紹了Connection、Command和DataAdapter等對象,本節我們將學習ADO.NET中不可缺少的事 ...
  • upstream模塊的使用方法1,使用upstream和server指令來選擇上游伺服器這兩個指令的語法如下圖:示例:2,對上游服務使用keepalive長連接負載均衡策略round-robin加權Round-Robin演算法是其它所有負載均衡演算法的基礎。 ...
  • 反向代理是nginx的一個非常重要的功能。反向代理nginx支持四層反向代理和七層反向代理,如下圖。負載均衡負載均衡是實現服務高性能和高可用的重要手段,而nginx是實現負載均衡的重要工具。 ...
  • 目錄:https://www.cnblogs.com/liqingwen/p/10261436.html 可以創建泛型類,像這樣 這是一個泛型類,它使用類型 T 作為 Write 方法中的方法參數。可以按這種方式去使用: 即使類本身不是泛型,也可以創建泛型方法。 請註意, ThingWriter 類 ...
  • 目錄:https://www.cnblogs.com/liqingwen/p/10261436.html 通過重寫 Equals 方法可以改善結構體相等比較的性能方法。 如果結構體包含引用類型欄位(而不是僅僅只有值類型,如 int)。 預設情況下,結構體的相等性是通過對記憶體中的兩個結構體對象進行逐字 ...
  • 目錄:https://www.cnblogs.com/liqingwen/p/10261436.html 當需要一系列整型值時,可以使用某種迴圈手動創建,或者可以使用 Enumerable.Range 方法。以下為代碼說明: var oneToTen = Enumerable.Range(1, 10 ...
  • " 【.NET Core項目實戰 統一認證平臺】開篇及目錄索引 " 上一篇我介紹了 的生成驗證及流程內容,相信大家也對 非常熟悉了,今天將從一個小眾的需求出發,介紹如何強制令牌過期的思路和實現過程。 .netcore項目實戰交流群(637326624),有興趣的朋友可以在群里交流討論。 一、前言 眾 ...
  • 聲明:問題雖然已經被解決,但是並沒有明白具體原理,歡迎大佬補充。 最近網站出現一個問題,在C#裡面使用 HttpWebRequest 類去發送post請求,偶爾 會出現 “套接字(協議/網路地址/埠)只允許使用一次” 的異常,很明顯應該是埠被占用。 原因排查: 1、網上說最多就是其他程式占用埠 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...