<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 MVC 過濾器之ActionFilter過濾器(2)

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

        asp.net core MVC 過濾器之ActionFilter過濾器(2)

        asp.net core MVC 過濾器之ActionFilter過濾器(2):本系類將會講解asp.net core MVC中的內置過濾器的使用,將分為以下章節 asp.net core MVC 過濾器之ExceptionFilter過濾器(一) asp.net core MVC 過濾器之ActionFilter過濾器(二) asp.net core MVC 過濾器之ResultFilte
        推薦度:
        導讀asp.net core MVC 過濾器之ActionFilter過濾器(2):本系類將會講解asp.net core MVC中的內置過濾器的使用,將分為以下章節 asp.net core MVC 過濾器之ExceptionFilter過濾器(一) asp.net core MVC 過濾器之ActionFilter過濾器(二) asp.net core MVC 過濾器之ResultFilte

        本系類將會講解asp.net core MVC中的內置過濾器的使用,將分為以下章節

          asp.net core MVC 過濾器之ExceptionFilter過濾器(一)

          asp.net core MVC 過濾器之ActionFilter過濾器(二)

          asp.net core MVC 過濾器之ResultFilter過濾器(三)

          asp.net core MVC 過濾器之ResourceFilter過濾器(四)

          asp.net core MVC 過濾器之AuthorizationFilter過濾器(五)

        簡介

        Action過濾器將在controller的Action執行之前和之后執行相應的方法。

        實現一個自定義Action過濾器

        自定義一個全局異常過濾器需要實現IActionFilter接口

        public class ActionFilter : IActionFilter
        {
         public void OnActionExecuted(ActionExecutedContext context)
         {
         Console.WriteLine("action執行之后");
         }
        
         public void OnActionExecuting(ActionExecutingContext context)
         {
         Console.WriteLine("action執行之前");
         }
        }
        
        

        IActionFilter需要實現兩個方法OnActionExecuted,OnActionExecuting。OnActionExecuting將在Action之前執行,OnActionExecuted在Action之后執行。

        知道原理之后我們們就可以利用其特性來簡化我們的代碼,在MVC中一個重要的概念就時Model驗證,我們定義Model約束,然后在Action中驗證Model是否綁定成功,我們的Action中重復地寫如下代碼

        [HttpGet]
        public ActionResult Get()
        {
         if (!ModelState.IsValid) return BadRequest("參數錯誤!");
        }
        

        這樣重復的代碼不僅增加代碼復雜都也不美觀,我們可以在ActionFilter中自動完成

        public void OnActionExecuting(ActionExecutingContext context)
        {
         if (context.ModelState.IsValid) return;
        
         var modelState = context.ModelState.FirstOrDefault(f => f.Value.Errors.Any());
         string errorMsg = modelState.Value.Errors.First().ErrorMessage;
         throw new AppException(errorMsg);
        }
        
        

        當Model綁定錯誤時,我們拋出異常信息,并在上一章節的異常過濾器ExceptionFilter中捕獲,返回錯誤信息給請求方。

        我們也可以利用ActionFilter的特性來記錄Action的執行時間,當Action執行時間過慢時輸出警告日志

        public class ActionFilter : IActionFilter
        {
         public void OnActionExecuted(ActionExecutedContext context)
         {
         var httpContext = context.HttpContext;
         var stopwach = httpContext.Items[Resources.StopwachKey] as Stopwatch;
         stopwach.Stop();
         var time = stopwach.Elapsed;
        
         if (time.TotalSeconds > 5)
         {
         var factory = context.HttpContext.RequestServices.GetService<ILoggerFactory>();
         var logger = factory.CreateLogger<ActionExecutedContext>();
         logger.LogWarning($"{context.ActionDescriptor.DisplayName}執行耗時:{time.ToString()}");
         }
         }
        
         public void OnActionExecuting(ActionExecutingContext context)
         {
         var stopwach = new Stopwatch();
         stopwach.Start();
         context.HttpContext.Items.Add(Resources.StopwachKey, stopwach);
         }
        }
        
        

        上面的代碼利用使用HttpContext傳遞一個Stopwach來計算action的執行時間,并在超過5秒時輸出警告日志。 

        注冊全局過濾器

        注冊方法與ExceptionFinter相同。找到系統根目錄Startup.cs文件,修改ConfigureServices方法如下

        services.AddMvc(options =>
         {
         options.Filters.Add<ActionFilter>();
         });

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

        文檔

        asp.net core MVC 過濾器之ActionFilter過濾器(2)

        asp.net core MVC 過濾器之ActionFilter過濾器(2):本系類將會講解asp.net core MVC中的內置過濾器的使用,將分為以下章節 asp.net core MVC 過濾器之ExceptionFilter過濾器(一) asp.net core MVC 過濾器之ActionFilter過濾器(二) asp.net core MVC 過濾器之ResultFilte
        推薦度:
        標簽: 過濾器 core action
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 日韩中文字幕免费| 国产在线播放免费| 亚洲av永久无码制服河南实里| 亚洲AV永久无码精品网站在线观看 | 国产美女无遮挡免费视频网站 | 久青草国产免费观看| 四虎精品亚洲一区二区三区| 美女视频黄a视频全免费网站一区 美女视频黄a视频全免费网站色 | 两个人看的www免费视频中文| 亚洲午夜国产精品无码老牛影视| 丁香花在线观看免费观看图片 | 好先生在线观看免费播放| 亚洲综合一区国产精品| 免费黄色一级毛片| 老司机午夜性生免费福利| 国产午夜亚洲精品国产成人小说| 精品国产免费一区二区三区| 久久国产亚洲精品麻豆| 日韩精品人妻系列无码专区免费| 91亚洲国产成人久久精品网站| 成人浮力影院免费看| 亚洲欧美成人综合久久久| 又黄又爽的视频免费看| 久久久久久久国产免费看| 亚洲激情在线视频| 在线播放免费播放av片| EEUSS影院WWW在线观看免费| 久久精品国产精品亚洲色婷婷| 成人黄色免费网址| 无码AV动漫精品一区二区免费 | 亚洲一区二区三区播放在线| 国产美女精品久久久久久久免费 | 成人a毛片免费视频观看| 国产亚洲精品岁国产微拍精品| 最近中文字幕无免费| 亚洲欧美国产精品专区久久| 自拍偷自拍亚洲精品被多人伦好爽| 免费国产污网站在线观看15| 国产精品亚洲专区在线播放| 亚洲四虎永久在线播放| 免费在线看片网站|