• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題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關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
    問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
    當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

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

    來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:35:23
    文檔

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

    asp.net core MVC 過(guò)濾器之ActionFilter過(guò)濾器(2):本系類(lèi)將會(huì)講解asp.net core MVC中的內(nèi)置過(guò)濾器的使用,將分為以下章節(jié) asp.net core MVC 過(guò)濾器之ExceptionFilter過(guò)濾器(一) asp.net core MVC 過(guò)濾器之ActionFilter過(guò)濾器(二) asp.net core MVC 過(guò)濾器之ResultFilte
    推薦度:
    導(dǎo)讀asp.net core MVC 過(guò)濾器之ActionFilter過(guò)濾器(2):本系類(lèi)將會(huì)講解asp.net core MVC中的內(nèi)置過(guò)濾器的使用,將分為以下章節(jié) asp.net core MVC 過(guò)濾器之ExceptionFilter過(guò)濾器(一) asp.net core MVC 過(guò)濾器之ActionFilter過(guò)濾器(二) asp.net core MVC 過(guò)濾器之ResultFilte

    本系類(lèi)將會(huì)講解asp.net core MVC中的內(nèi)置過(guò)濾器的使用,將分為以下章節(jié)

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

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

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

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

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

    簡(jiǎn)介

    Action過(guò)濾器將在controller的Action執(zhí)行之前和之后執(zhí)行相應(yīng)的方法。

    實(shí)現(xiàn)一個(gè)自定義Action過(guò)濾器

    自定義一個(gè)全局異常過(guò)濾器需要實(shí)現(xiàn)IActionFilter接口

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

    IActionFilter需要實(shí)現(xiàn)兩個(gè)方法OnActionExecuted,OnActionExecuting。OnActionExecuting將在Action之前執(zhí)行,OnActionExecuted在Action之后執(zhí)行。

    知道原理之后我們們就可以利用其特性來(lái)簡(jiǎn)化我們的代碼,在MVC中一個(gè)重要的概念就時(shí)Model驗(yàn)證,我們定義Model約束,然后在Action中驗(yàn)證Model是否綁定成功,我們的Action中重復(fù)地寫(xiě)如下代碼

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

    這樣重復(fù)的代碼不僅增加代碼復(fù)雜都也不美觀(guān),我們可以在ActionFilter中自動(dòng)完成

    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);
    }
    
    

    當(dāng)Model綁定錯(cuò)誤時(shí),我們拋出異常信息,并在上一章節(jié)的異常過(guò)濾器ExceptionFilter中捕獲,返回錯(cuò)誤信息給請(qǐng)求方。

    我們也可以利用ActionFilter的特性來(lái)記錄Action的執(zhí)行時(shí)間,當(dāng)Action執(zhí)行時(shí)間過(guò)慢時(shí)輸出警告日志

    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}執(zhí)行耗時(shí):{time.ToString()}");
     }
     }
    
     public void OnActionExecuting(ActionExecutingContext context)
     {
     var stopwach = new Stopwatch();
     stopwach.Start();
     context.HttpContext.Items.Add(Resources.StopwachKey, stopwach);
     }
    }
    
    

    上面的代碼利用使用HttpContext傳遞一個(gè)Stopwach來(lái)計(jì)算action的執(zhí)行時(shí)間,并在超過(guò)5秒時(shí)輸出警告日志。 

    注冊(cè)全局過(guò)濾器

    注冊(cè)方法與ExceptionFinter相同。找到系統(tǒng)根目錄Startup.cs文件,修改ConfigureServices方法如下

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

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

    文檔

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

    asp.net core MVC 過(guò)濾器之ActionFilter過(guò)濾器(2):本系類(lèi)將會(huì)講解asp.net core MVC中的內(nèi)置過(guò)濾器的使用,將分為以下章節(jié) asp.net core MVC 過(guò)濾器之ExceptionFilter過(guò)濾器(一) asp.net core MVC 過(guò)濾器之ActionFilter過(guò)濾器(二) asp.net core MVC 過(guò)濾器之ResultFilte
    推薦度:
    標(biāo)簽: 過(guò)濾器 core action
    • 熱門(mén)焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門(mén)推薦

    專(zhuān)題
    Top
    主站蜘蛛池模板: 日韩精品少妇无码受不了| 久久精品99久久香蕉国产色戒| 亚洲欧美一级久久精品| 欧美精品一区二区三区视频| 久久亚洲欧美国产精品| 欧美激情精品久久久久久久| 98香蕉草草视频在线精品看| 99精品高清视频一区二区| 日韩精品久久久肉伦网站| 亚洲麻豆精品国偷自产在线91| 欧美日韩精品| 久热精品人妻视频| 精品国产一级在线观看| 国产三级精品三级在线观看| 亚洲精品高清视频| 国产精品欧美亚洲韩国日本| 国产亚洲精品精华液| 久久久久无码精品国产不卡| 亚洲精品制服丝袜四区| 亚洲а∨天堂久久精品9966| 青草青草久热精品视频在线观看| 精品伦精品一区二区三区视频| 国产精品美女WWW爽爽爽视频| 91麻豆精品国产91久久久久久| 久久精品免费观看| 久久久91精品国产一区二区三区 | 亚洲精品欧美二区三区中文字幕| 久久精品无码一区二区三区日韩 | AAA级久久久精品无码区| 午夜精品美女自拍福到在线| 亚洲午夜精品一区二区| 无码人妻丰满熟妇精品区| 精品国内自产拍在线观看| 国产福利电影一区二区三区久久久久成人精品综合 | 成人精品综合免费视频| 久久99精品久久久久婷婷| 日韩精品无码一区二区中文字幕| 亚洲欧美精品AAAAAA片| 中文字幕精品无码久久久久久3D日动漫| 久久精品国产一区二区三区| 久久99精品久久久久久秒播|