<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 5 & MVC6系列教程(15):MvcOptions配置

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

        解讀ASP.NET 5 & MVC6系列教程(15):MvcOptions配置

        解讀ASP.NET 5 & MVC6系列教程(15):MvcOptions配置:程序模型處理 IApplicationModelConvention 在MvcOptions的實例對象上,有一個ApplicationModelConventions屬性(類型是:List<IApplicationModelConvention>),該屬性IApplicationModelConvention類型的接口集合
        推薦度:
        導讀解讀ASP.NET 5 & MVC6系列教程(15):MvcOptions配置:程序模型處理 IApplicationModelConvention 在MvcOptions的實例對象上,有一個ApplicationModelConventions屬性(類型是:List<IApplicationModelConvention>),該屬性IApplicationModelConvention類型的接口集合

        程序模型處理 IApplicationModelConvention

        MvcOptions的實例對象上,有一個ApplicationModelConventions屬性(類型是:List<IApplicationModelConvention>),該屬性IApplicationModelConvention類型的接口集合,用于處理應用模型ApplicationModel,該集合是在MVC程序啟動的時候進行調用,所以在調用之前,我們可以對其進行修改或更新,比如,我們可以針對所有的Controller和Action在數據庫中進行授權定義,在程序啟動的時候讀取數據授權信息,然后對應用模型ApplicationModel進行處理。 示例如下:

        public class PermissionCheckApplicationModelConvention : IApplicationModelConvention
        {
         public void Apply(ApplicationModel application)
         {
         foreach (var controllerModel in application.Controllers)
         {
         var controllerType = controllerModel.ControllerType;
         var controllerName = controllerModel.ControllerName;
        
         controllerModel.Actions.ToList().ForEach(actionModel =>
         {
         var actionName = actionModel.ActionName;
         var parameters = actionModel.Parameters;
        
         // 根據判斷條件,操作修改actionModel
         });
        
         // 根據判斷條件,操作修改ControllerModel
         }
         }
        }

        視圖引擎的管理ViewEngines

        在MvcOptions的實例對象中,有一個ViewEngines屬性用于保存系統(tǒng)的視圖引擎集合,以便可以讓我們實現自己的自定義視圖引擎,比如在《自定義View視圖文件查找邏輯》章節(jié)中,我們就利用了該特性,來實現了自己的自定義視圖引擎,示例如下:

        services.AddMvc().Configure<MvcOptions>(options =>
        {
         options.ViewEngines.Clear();
         options.ViewEngines.Add(typeof(ThemeViewEngine));
        });

        Web API中的輸入(InputFormater)/輸出(OutputFormater)

        輸入

        Web API和目前的MVC的輸入參數的處理,目前支持JSON和XML格式,具體的處理類分別如下:

        JsonInputFormatter
        XmlDataContractSerializerInputFormatter

        輸出

        在Web API中,默認的輸出格式化器有如下四種:

        HttpNoContentOutputFormatter
        StringOutputFormatter
        JsonOutputFormatter
        XmlDataContractSerializerOutputFormatter

        上述四種在系統(tǒng)中,是根據不同的情形自動進行判斷輸出的,具體判斷規(guī)則如下:

        如果是如下類似的Action,則使用HttpNoContentOutputFormatter返回204,即NoContent。

        public Task DoSomethingAsync()
        {
         // 返回Task
        }
        
        public void DoSomething()
        {
         // Void方法
        }
        
        public string GetString()
        {
         return null; // 返回null
        }
        
        public List<Data> GetData()
        {
         return null; // 返回null
        }

        如果是如下方法,同樣是返回字符串,只有返回類型是string的Action,才使用StringOutputFormatter返回字符串;返回類型是object的Action,則使用JsonOutputFormatter返回JSON類型的字符串數據。

        public object GetData()
        {
         return"The Data"; // 返回JSON
        }
        
        public string GetString()
        {
         return"The Data"; // 返回字符串
        }

        如果上述兩種類型的Action都不是,則默認使用JsonOutputFormatter返回JSON數據,如果JsonOutputFormatter格式化器通過如下語句被刪除了,那就會使用XmlDataContractSerializerOutputFormatter返回XML數據。

        services.Configure<MvcOptions>(options =>
         options.OutputFormatters.RemoveAll(formatter => formatter.Instance is JsonOutputFormatter)
        );

        當然,你也可以使用ProducesAttribute顯示聲明使用JsonOutputFormatter格式化器,示例如下。

        public class Product2Controller : Controller
        {
         [Produces("application/json")]
         //[Produces("application/xml")]
         public Product Detail(int id)
         {
         return new Product() { ProductId = id, ProductName = "商品名稱" };
         }
        }

        或者,可以在基類Controller上,也可以使用ProducesAttribute,示例如下:

        [Produces("application/json")]
        public class JsonController : Controller { }
        
        public class HomeController : JsonController
        {
         public List<Data> GetMeData()
         {
         return GetDataFromSource();
         }
        }

        當然,也可以在全局范圍內聲明該ProducesAttribute,示例如下:

        services.Configure<MvcOptions>(options =>
         options.Filters.Add(newProducesAttribute("application/json"))
        );

        Output Cache 與 Profile

        在MVC6中,OutputCache的特性由ResponseCacheAttribute類來支持,示例如下:

        [ResponseCache(Duration = 100)]
        public IActionResult Index()
        {
         return Content(DateTime.Now.ToString());
        }

        上述示例表示,將該頁面的內容在客戶端緩存100秒,換句話說,就是在Response響應頭header里添加一個Cache-Control頭,并設置max-age=100。 該特性支持的屬性列表如下:

        屬性名稱 描述
        Duration 緩存時間,單位:秒,示例:Cache-Control:max-age=100
        NoStore true則設置Cache-Control:no-store
        VaryByHeader 設置Vary header頭
        Location 緩存位置,如將Cache-Control設置為public, private或no-cache。

        另外,ResponseCacheAttribute還支持一個CacheProfileName屬性,以便可以讀取全局設置的profile信息配置,進行緩存,示例如下:

        [ResponseCache(CacheProfileName = "MyProfile")]
        public IActionResult Index()
        {
         return Content(DateTime.Now.ToString());
        }
        
        public void ConfigureServices(IServiceCollection services)
        {
         services.Configure<MvcOptions>(options =>
         {
         options.CacheProfiles.Add("MyProfile",
         new CacheProfile
         {
         Duration = 100
         });
         });
        }

        通過向MvcOptionsCacheProfiles屬性值添加一個名為MyProfile的個性設置,可以在所有的Action上都使用該配置信息。

        其它我們已經很熟悉的內容

        以下內容我們可能都已經非常熟悉了,因為在之前的MVC版本中都已經使用過了,這些內容均作為MvcOptions的屬性而存在,具體功能列表如下(就不一一敘述了):

        FiltersModelBindersModelValidatorProvidersValidationExcludeFiltersValueProviderFactories

        另外兩個:
        MaxModelValidationErrors
        置模型驗證是顯示的最大錯誤數量。

        RespectBrowserAcceptHeader
        在使用Web API的內容協(xié)定功能時,是否遵守Accept Header的定義,默認情況下當media type默認是*/*的時候是忽略Accept header的。如果設置為true,則不忽略。

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

        文檔

        解讀ASP.NET 5 & MVC6系列教程(15):MvcOptions配置

        解讀ASP.NET 5 & MVC6系列教程(15):MvcOptions配置:程序模型處理 IApplicationModelConvention 在MvcOptions的實例對象上,有一個ApplicationModelConventions屬性(類型是:List<IApplicationModelConvention>),該屬性IApplicationModelConvention類型的接口集合
        推薦度:
        標簽: &amp; ): ASP.NET
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲午夜一区二区电影院| 亚洲国产精品成人久久久| 国产在线一区二区综合免费视频| 亚洲麻豆精品果冻传媒| 免费观看美女裸体网站| 中文成人久久久久影院免费观看| 亚洲视频国产精品| 免费国产成人午夜电影| 在线看无码的免费网站| 少妇亚洲免费精品| 亚洲综合激情另类小说区| 免费A级毛片无码A∨男男| 久久永久免费人妻精品下载| 国产亚洲精品欧洲在线观看| 久久久久亚洲Av无码专| 亚洲国模精品一区| 毛片视频免费观看| 国产免费拔擦拔擦8X高清在线人| 久久综合亚洲色hezyo| 亚洲Aⅴ无码专区在线观看q| 国产高清免费在线| 亚洲精品国产免费| 国内精品99亚洲免费高清| 亚洲youwu永久无码精品| 亚洲理论精品午夜电影| 久久精品国产亚洲精品| 好男人视频社区精品免费| 三年片在线观看免费大全电影| 精品亚洲成A人在线观看青青| 亚洲欧洲视频在线观看| 亚洲精品国产美女久久久| 全黄a免费一级毛片人人爱| 一二三四在线播放免费观看中文版视频 | 亚洲精华国产精华精华液网站| 久久久亚洲精品视频| 精品国产亚洲男女在线线电影 | 99久久精品日本一区二区免费| 国产一级a毛一级a看免费人娇| 成人精品国产亚洲欧洲| 亚洲AV日韩综合一区尤物| 亚洲美女免费视频|