ASP.NET Core 中間件的使用之全局異常處理機制
前言:
我們經(jīng)常聽到“秒修復秒上線”,覺得很厲害的樣子。
其實不然,這只是一個調(diào)侃而已,出現(xiàn)問題的方式很多(邏輯漏洞、代碼異常、操作方式不正確等)。
我們今天來說代碼異常問題怎么快速定位,減少不必要的時間浪費。
這就是今天的主題“添加全局異常處理機制”捕捉異常存儲到數(shù)據(jù)庫(mongodb、SqlServer、MySQL等)。
PS:輸出txt的話不怎么友好,不是所有人都能登錄服務(wù)器的。
異常是一種運行時錯誤,當異常沒有得到適當?shù)奶幚?,很可能會導致你的程序意外終止。
1、創(chuàng)建項目
我們創(chuàng)建一個ASP.NET Core Web API項目,選擇.NET Core3.1。

2、創(chuàng)建全局異常過濾器
在控制器里面創(chuàng)建一個異常過濾器,命名為ExceptionFilter.cs,過濾器繼承IExceptionFilter接口。
注意,我這里入庫用的是efcore+sqlserver,大家可以根據(jù)自己實際情況使用ORM和數(shù)據(jù)庫方式。
異常過濾器,顧名思義,就是當程序發(fā)生異常時所使用的過濾器。用于在系統(tǒng)出現(xiàn)未捕獲異常時的處理。
實現(xiàn)一個自定義異常過濾器,自定義一個全局異常過濾器需要實現(xiàn)IExceptionFilter接口。
IExceptionFilter接口會要求實現(xiàn)OnException方法,當系統(tǒng)發(fā)生未捕獲異常時就會觸發(fā)這個方法。
OnException方法有一個ExceptionContext異常上下文,其中包含了具體的異常信息,HttpContext及mvc路由信息。
系統(tǒng)一旦出現(xiàn)未捕獲異常后,比較常見的做法就是使用日志工具,將異常的詳細信息記錄下來,方便修正調(diào)試。
下面是日志記錄的實現(xiàn):
using Microsoft.AspNetCore.Mvc.Filters;
using System;
namespace Log4NetWebAPI.Controllers
{
public class ExceptionFilter: IExceptionFilter
{
//全局異常處理機制
public void OnException(ExceptionContext context)
{
Exception ex = context.Exception;
//錯誤所在的控制器方法名稱
var DisplayName = context.ActionDescriptor.DisplayName;
#region 錯誤所在的行號行號
////行號前的名稱有的是中文,有的是英文,注意甄別
//var aaa = ex.StackTrace.Substring(ex.StackTrace.IndexOf("行號"), ex.StackTrace.Length - ex.StackTrace.IndexOf("行號"));
//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; //錯誤位置
md.lineNumber = lineNumber; //錯誤行號
md.message = ex.Message; //錯誤信息
md.messagedetails = ex.ToString(); //錯誤詳情
md.createTime= DateTime.Now;
using (var ctx = new dbContext())
{
ctx.Add(md);
ctx.SaveChanges();
}
#endregion
//下面是你的返回頁面顯示的內(nèi)容提示,以下省略
}
}
}
3、依賴注入全局異常處理機制
在Startup.cs里面把我們剛剛創(chuàng)建的全局異常處理機制注入到中間件來,放到ConfigureServices方法里面。
//添加全局異常處理機制
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();
//添加全局異常處理機制
services.AddMvc(option => {
option.Filters.Add<ExceptionFilter>();
});
}
4、測試全局異常處理機制
“將string字符串轉(zhuǎn)換為int類型”,如下代碼,肯定是報錯的,我們來捕捉一下錯誤信息入庫。
var numberNo = "我是序列號";
//這里是轉(zhuǎn)換為int類型,然后數(shù)據(jù)源是string,肯定報錯,然后我們?nèi)植蹲?br /> //注意,我們這里沒有寫try catch
var number = Convert.ToInt32(numberNo);
運行項目后我們查詢一下數(shù)據(jù)庫,發(fā)現(xiàn)捕捉到錯誤信息了,包括
錯誤時間:2021-09-28 15:12:58.307
日志類型:error
錯誤的方法位置:Log4NetWebAPI.Controllers.WeatherForecastController.Get (Log4NetWebAPI),
錯誤的行號:36行,
錯誤的信息:Input string was not in a correct format.(輸入字符串的格式不正確。)

下面是控制器方法截圖


到此這篇關(guān)于ASP.NET Core 中間件的使用之全局異常處理機制的文章就介紹到這了,更多相關(guān)ASP.NET Core 全局異常處理機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
.Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解
這篇文章主要為大家介紹了.Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
.NET 6新特性試用Timer類之PeriodicTimer?
這篇文章主要介紹了.NET 6新特性試用Timer類之PeriodicTimer,PeriodicTimer與其他Timer需要創(chuàng)建事件回調(diào)不同,下,下面文章詳細介紹PeriodicTimer的使用方式,需要的朋友可以參考一下2022-02-02
ASP.NET Web API教程 創(chuàng)建Admin視圖詳細介紹
現(xiàn)在我們轉(zhuǎn)入客戶端,并添加一個能夠使用從Admin控制器而來的數(shù)據(jù)的頁面。通過給控制器發(fā)送AJAX請求的方式,該頁面將允許用戶創(chuàng)建、編輯,或刪除產(chǎn)品2012-11-11
一文透徹詳解.NET框架類型系統(tǒng)設(shè)計要點
這篇文章主要為大家透徹詳解了選擇.NET框架的n個理由,本系列的第一篇文章全面概述了平臺的支柱和設(shè)計要點,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05

