亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ASP.NET Core 中間件的使用之全局異常處理機(jī)制

 更新時(shí)間:2021年09月29日 17:24:00   作者:熊澤-學(xué)習(xí)中的苦與樂  
我們今天這篇文章就來說說代碼異常問題怎么快速定位,減少不必要的時(shí)間浪費(fèi)。異常是一種運(yùn)行時(shí)錯(cuò)誤,當(dāng)異常沒有得到適當(dāng)?shù)奶幚恚芸赡軙?huì)導(dǎo)致你的程序意外終止。下面雄安邊將詳細(xì)介紹,需要的朋友可以參考下

前言:

我們經(jīng)常聽到“秒修復(fù)秒上線”,覺得很厲害的樣子。

其實(shí)不然,這只是一個(gè)調(diào)侃而已,出現(xiàn)問題的方式很多(邏輯漏洞、代碼異常、操作方式不正確等)。

我們今天來說代碼異常問題怎么快速定位,減少不必要的時(shí)間浪費(fèi)。

這就是今天的主題“添加全局異常處理機(jī)制”捕捉異常存儲(chǔ)到數(shù)據(jù)庫(mongodb、SqlServer、MySQL等)。

PS:輸出txt的話不怎么友好,不是所有人都能登錄服務(wù)器的。

異常是一種運(yùn)行時(shí)錯(cuò)誤,當(dāng)異常沒有得到適當(dāng)?shù)奶幚?,很可能?huì)導(dǎo)致你的程序意外終止。

1、創(chuàng)建項(xiàng)目

我們創(chuàng)建一個(gè)ASP.NET Core Web API項(xiàng)目,選擇.NET Core3.1。

2、創(chuàng)建全局異常過濾器

在控制器里面創(chuàng)建一個(gè)異常過濾器,命名為ExceptionFilter.cs,過濾器繼承IExceptionFilter接口。

注意,我這里入庫用的是efcore+sqlserver,大家可以根據(jù)自己實(shí)際情況使用ORM和數(shù)據(jù)庫方式。

 異常過濾器,顧名思義,就是當(dāng)程序發(fā)生異常時(shí)所使用的過濾器。用于在系統(tǒng)出現(xiàn)未捕獲異常時(shí)的處理。

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

 IExceptionFilter接口會(huì)要求實(shí)現(xiàn)OnException方法,當(dāng)系統(tǒng)發(fā)生未捕獲異常時(shí)就會(huì)觸發(fā)這個(gè)方法。

OnException方法有一個(gè)ExceptionContext異常上下文,其中包含了具體的異常信息,HttpContextmvc路由信息。

系統(tǒng)一旦出現(xiàn)未捕獲異常后,比較常見的做法就是使用日志工具,將異常的詳細(xì)信息記錄下來,方便修正調(diào)試。

下面是日志記錄的實(shí)現(xiàn):

using Microsoft.AspNetCore.Mvc.Filters;
using System;

namespace Log4NetWebAPI.Controllers
{
    public class ExceptionFilter: IExceptionFilter
    {
        //全局異常處理機(jī)制
        public void OnException(ExceptionContext context)
        {
            Exception ex = context.Exception;

            //錯(cuò)誤所在的控制器方法名稱
            var DisplayName = context.ActionDescriptor.DisplayName;

            #region 錯(cuò)誤所在的行號(hào)行號(hào)

            ////行號(hào)前的名稱有的是中文,有的是英文,注意甄別
            //var aaa = ex.StackTrace.Substring(ex.StackTrace.IndexOf("行號(hào)"), ex.StackTrace.Length - ex.StackTrace.IndexOf("行號(hào)"));
            //var ccc = ex.StackTrace.Substring(ex.StackTrace.IndexOf("line"), ex.StackTrace.Length - ex.StackTrace.IndexOf("line"));
            var lineNumber = 0;
            const string lineSearch = ":line ";
            var index = ex.StackTrace.LastIndexOf(lineSearch);
            if (index != -1)
            {
                var lineNumberText = ex.StackTrace.Substring(index + lineSearch.Length);
                var lineNumberStr = lineNumberText.Substring(0, lineNumberText.IndexOf("\r\n"));
                if (int.TryParse(lineNumberStr, out lineNumber))
                {

                }
            }

            #endregion

            #region 寫入信息到【數(shù)據(jù)庫】,這里自行入庫即可(mongodb、SqlServer、MySQL等),我以SqlServer為例

            errorLog md = new errorLog();
            md.logTime = DateTime.Now;
            md.logType = "error";
            md.displayName = DisplayName;  //錯(cuò)誤位置
            md.lineNumber = lineNumber;  //錯(cuò)誤行號(hào)
            md.message = ex.Message;    //錯(cuò)誤信息
            md.messagedetails = ex.ToString();  //錯(cuò)誤詳情
            md.createTime= DateTime.Now;

            using (var ctx = new dbContext())
            {

                ctx.Add(md);
                ctx.SaveChanges();
            }
            #endregion

            //下面是你的返回頁面顯示的內(nèi)容提示,以下省略

        }
    }
}

3、依賴注入全局異常處理機(jī)制

Startup.cs里面把我們剛剛創(chuàng)建的全局異常處理機(jī)制注入到中間件來,放到ConfigureServices方法里面。

//添加全局異常處理機(jī)制
services.AddMvc(option => {
  option.Filters.Add<ExceptionFilter>();
});

// This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddControllers();

            //添加全局異常處理機(jī)制
            services.AddMvc(option => {
                option.Filters.Add<ExceptionFilter>();
            });
        }
            

4、測試全局異常處理機(jī)制

“將string字符串轉(zhuǎn)換為int類型”,如下代碼,肯定是報(bào)錯(cuò)的,我們來捕捉一下錯(cuò)誤信息入庫。

var numberNo = "我是序列號(hào)";
//這里是轉(zhuǎn)換為int類型,然后數(shù)據(jù)源是string,肯定報(bào)錯(cuò),然后我們?nèi)植蹲?br /> //注意,我們這里沒有寫try catch
var number = Convert.ToInt32(numberNo);

運(yùn)行項(xiàng)目后我們查詢一下數(shù)據(jù)庫,發(fā)現(xiàn)捕捉到錯(cuò)誤信息了,包括

錯(cuò)誤時(shí)間:2021-09-28 15:12:58.307

日志類型:error

錯(cuò)誤的方法位置:Log4NetWebAPI.Controllers.WeatherForecastController.Get (Log4NetWebAPI),

錯(cuò)誤的行號(hào):36行,

錯(cuò)誤的信息:Input string was not in a correct format.(輸入字符串的格式不正確。)

下面是控制器方法截圖

到此這篇關(guān)于ASP.NET Core 中間件的使用之全局異常處理機(jī)制的文章就介紹到這了,更多相關(guān)ASP.NET Core 全局異常處理機(jī)制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • .Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解

    .Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解

    這篇文章主要為大家介紹了.Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • ASP.NET常用代碼

    ASP.NET常用代碼

    ASP.NET常用代碼...
    2006-06-06
  • 一個(gè)經(jīng)典的ADO.NET入門例子

    一個(gè)經(jīng)典的ADO.NET入門例子

    一個(gè)經(jīng)典的ADO.NET入門例子...
    2006-07-07
  • 修改 asp.net core 5 程序的默認(rèn)端口號(hào)

    修改 asp.net core 5 程序的默認(rèn)端口號(hào)

    這篇文章主要介紹了修改 asp.net core 5 程序的默認(rèn)端口號(hào),我們知道可以通過修改 launchSettings.json 文件中的端口號(hào)來實(shí)現(xiàn)端口切換,下面來看看具體的修改過程吧
    2022-01-01
  • .NET 6新特性試用Timer類之PeriodicTimer?

    .NET 6新特性試用Timer類之PeriodicTimer?

    這篇文章主要介紹了.NET 6新特性試用Timer類之PeriodicTimer,PeriodicTimer與其他Timer需要?jiǎng)?chuàng)建事件回調(diào)不同,下,下面文章詳細(xì)介紹PeriodicTimer的使用方式,需要的朋友可以參考一下
    2022-02-02
  • 使用.NET6實(shí)現(xiàn)動(dòng)態(tài)API

    使用.NET6實(shí)現(xiàn)動(dòng)態(tài)API

    本文詳細(xì)講解了使用.NET6實(shí)現(xiàn)動(dòng)態(tài)API,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • ASP.NET的Core AD域登錄過程示例

    ASP.NET的Core AD域登錄過程示例

    這篇文章主要為大家介紹了ASP.NET Core AD域登錄過程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • ASP.NET Web API教程 創(chuàng)建Admin視圖詳細(xì)介紹

    ASP.NET Web API教程 創(chuàng)建Admin視圖詳細(xì)介紹

    現(xiàn)在我們轉(zhuǎn)入客戶端,并添加一個(gè)能夠使用從Admin控制器而來的數(shù)據(jù)的頁面。通過給控制器發(fā)送AJAX請求的方式,該頁面將允許用戶創(chuàng)建、編輯,或刪除產(chǎn)品
    2012-11-11
  • ASP.NET Core 中間件的使用之全局異常處理機(jī)制

    ASP.NET Core 中間件的使用之全局異常處理機(jī)制

    我們今天這篇文章就來說說代碼異常問題怎么快速定位,減少不必要的時(shí)間浪費(fèi)。異常是一種運(yùn)行時(shí)錯(cuò)誤,當(dāng)異常沒有得到適當(dāng)?shù)奶幚?,很可能?huì)導(dǎo)致你的程序意外終止。下面雄安邊將詳細(xì)介紹,需要的朋友可以參考下
    2021-09-09
  • 一文透徹詳解.NET框架類型系統(tǒng)設(shè)計(jì)要點(diǎn)

    一文透徹詳解.NET框架類型系統(tǒng)設(shè)計(jì)要點(diǎn)

    這篇文章主要為大家透徹詳解了選擇.NET框架的n個(gè)理由,本系列的第一篇文章全面概述了平臺(tái)的支柱和設(shè)計(jì)要點(diǎn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05

最新評論