<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        asp.net core webapi項目配置全局路由的方法示例

        來源:懂視網 責編:小采 時間:2020-11-27 22:34:55
        文檔

        asp.net core webapi項目配置全局路由的方法示例

        asp.net core webapi項目配置全局路由的方法示例:一、前言 在開發項目的過程中,我新創建了一個controller,發現vs會給我們直接在controller頭添加前綴,比如[Route(api/[controller])],即在訪問接口的時候會變成http://localhost:8000/api/values,但是如果控制器有很多個,或者要進行版本
        推薦度:
        導讀asp.net core webapi項目配置全局路由的方法示例:一、前言 在開發項目的過程中,我新創建了一個controller,發現vs會給我們直接在controller頭添加前綴,比如[Route(api/[controller])],即在訪問接口的時候會變成http://localhost:8000/api/values,但是如果控制器有很多個,或者要進行版本

        一、前言

        在開發項目的過程中,我新創建了一個controller,發現vs會給我們直接在controller頭添加前綴,比如[Route("api/[controller]")],即在訪問接口的時候會變成http://localhost:8000/api/values,但是如果控制器有很多個,或者要進行版本迭代時,我們會發現痛苦的時刻降臨了,要一個一個的修改。

        如果在這個時候可以進行全局配置前綴那真是福利呀,修改一處即可。為了能達到此目的我們就來運用一下吧。

        二、配置

        0、在配置前我們先來看看接口的前綴吧。 立圖為證 

        用swagger打開

        1、我們需要用到 IApplicationModelConvention  這個接口,它是位于 Microsoft.AspNetCore.Mvc.ApplicationModels 命令空間下面。

        MVC框架有一些約定俗成的東西,這個接口主就是用來定義一些MVC約定的東西。我們就可以通過 Apply方法中的 ApplicationModel  來修改或者添加一些約定,而且MV框架本身在啟動的時候會把此接口注入,以便于我們使用。

        不過我們還是要來看一下這個ApplicationModel  對象里面有什么我們可以用到的地方,我們繼續深入:

        看到這是不是很爽,我們可以看一下 每個屬性的給出的解釋

        ApiExplorerModel:包括描述信息,群組信息,可見性等。

        ControllerModel:主要是 Comtroller 默認約定相關的了,這個里面東西就比較多了,有 控制器名稱、路由值、Actions等,我們接下去的配置也將會在此展開

        IFilterMetadata :空接口,主要起到標記的作用。

        2、配置

        第一步:先定義一個類,用來實現IApplicationModelConvention  接口。

        /// <summary>
         /// 全局路由前綴配置
         /// </summary>
         public class RouteConvention : IApplicationModelConvention
         {
         /// <summary>
         /// 定義一個路由前綴變量
         /// </summary>
         private readonly AttributeRouteModel _centralPrefix;
         /// <summary>
         /// 調用時傳入指定的路由前綴
         /// </summary>
         /// <param name="routeTemplateProvider"></param>
         public RouteConvention(IRouteTemplateProvider routeTemplateProvider)
         {
         _centralPrefix = new AttributeRouteModel(routeTemplateProvider);
         }
        
         //接口的Apply方法
         public void Apply(ApplicationModel application)
         {
         //遍歷所有的 Controller
         foreach (var controller in application.Controllers)
         {
         // 1、已經標記了 RouteAttribute 的 Controller
                 //這一塊需要注意,如果在控制器中已經標注有路由了,則會在路由的前面再添加指定的路由內容。
        
         var matchedSelectors = controller.Selectors.Where(x => x.AttributeRouteModel != null).ToList();
         if (matchedSelectors.Any())
         {
         foreach (var selectorModel in matchedSelectors)
         {
         // 在 當前路由上 再 添加一個 路由前綴
         selectorModel.AttributeRouteModel = AttributeRouteModel.CombineAttributeRouteModel(_centralPrefix,
         selectorModel.AttributeRouteModel);
         }
         }
        
         //2、 沒有標記 RouteAttribute 的 Controller
         var unmatchedSelectors = controller.Selectors.Where(x => x.AttributeRouteModel == null).ToList();
         if (unmatchedSelectors.Any())
         {
         foreach (var selectorModel in unmatchedSelectors)
         {
         // 添加一個 路由前綴
         selectorModel.AttributeRouteModel = _centralPrefix;
         }
         }
         }
         }
         }

        此處代碼需要注意下,上面代碼分為兩部分,一部分是控制器有路由配置,一部分是沒有路由配置。因此需要根據具體的情況來選擇使用。

        第二步:添加上面后,我們就定義一個類來插入我們的路由吧。

        定義MvcOptionsExtensions.cs,此方法主要是擴展了MVCoptions類

        public static class MvcOptionsExtensions
         {
         /// <summary>
         /// 擴展方法
         /// </summary>
         /// <param name="opts"></param>
         /// <param name="routeAttribute"></param>
         public static void UseCentralRoutePrefix(this MvcOptions opts, IRouteTemplateProvider routeAttribute)
         {
         // 添加我們自定義 實現IApplicationModelConvention的RouteConvention
         opts.Conventions.Insert(0, new RouteConvention(routeAttribute));
         }
         }

        說明:routeAttribute 為我們自定的前綴內容。

        第三步:在startup.cs 里面ConfigureServices 方法添加配置信息

        #region 配置全局路由
         //在各個控制器添加前綴(沒有特定的路由前面添加前綴)
         services.AddMvc(opt =>
         {
         opt.UseCentralRoutePrefix(new RouteAttribute("lg/v1/[action]"));
         //opt.UseCentralRoutePrefix(new RouteAttribute("api/[controller]/[action]"));
        
         });
         #endregion

        說明:上面的方括號在這邊是有效的。其中內容可以自定義。

        第四步:運行

        1、原先控制器路由前綴保留

        2、把原先的路由前綴去除

        三、總結

        至此,已很好的實現全局路由配置前綴啦??梢蚤_心的玩耍啦。

        github代碼地址:github

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        asp.net core webapi項目配置全局路由的方法示例

        asp.net core webapi項目配置全局路由的方法示例:一、前言 在開發項目的過程中,我新創建了一個controller,發現vs會給我們直接在controller頭添加前綴,比如[Route(api/[controller])],即在訪問接口的時候會變成http://localhost:8000/api/values,但是如果控制器有很多個,或者要進行版本
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 中文字幕无码不卡免费视频| 性xxxxx免费视频播放| 亚洲A∨午夜成人片精品网站| 亚洲高清一区二区三区电影| 毛片高清视频在线看免费观看| 亚洲喷奶水中文字幕电影 | 国产免费牲交视频免费播放| 亚洲午夜福利精品无码| 曰韩无码AV片免费播放不卡| 综合亚洲伊人午夜网| 中文字幕一区二区三区免费视频| 亚洲熟妇av一区二区三区| a级成人毛片免费图片| 久久精品国产亚洲香蕉| 99久久久国产精品免费牛牛四川| 久久综合亚洲色HEZYO社区| 国产成人免费在线| 亚洲精品无码国产片| 亚洲 另类 无码 在线| 中国内地毛片免费高清| 亚洲天堂中文字幕| 国产精品久久久久免费a∨| 春暖花开亚洲性无区一区二区| 亚洲国产精品碰碰| 老司机69精品成免费视频| 亚洲成人高清在线观看| 青青青国产免费一夜七次郎| 国产成人高清精品免费观看| 亚洲成年轻人电影网站www| 国产免费看JIZZ视频| 美女又黄又免费的视频| 亚洲一区AV无码少妇电影☆| **一级毛片免费完整视| 色天使亚洲综合一区二区| 亚洲日韩欧洲无码av夜夜摸| 国产又黄又爽又猛免费app| 边摸边吃奶边做爽免费视频网站 | 亚洲色偷偷色噜噜狠狠99网| 亚洲精品线路一在线观看| 91久久精品国产免费一区| 国产亚洲精品美女久久久久|