国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - ASP.NET Core 中間件的使用之全局異常處理機制

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

2021-12-20 15:53熊澤-學習中的苦與樂 ASP.NET教程

我們今天這篇文章就來說說代碼異常問題怎么快速定位,減少不必要的時間浪費。異常是一種運行時錯誤,當異常沒有得到適當的處理,很可能會導致你的程序意外終止。下面雄安邊將詳細介紹,需要的朋友可以參考下

前言:

我們經常聽到“秒修復秒上線”,覺得很厲害的樣子。

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

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

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

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

異常是一種運行時錯誤,當異常沒有得到適當的處理,很可能會導致你的程序意外終止。

 

1、創建項目

我們創建一個ASP.NET Core Web API項目,選擇.NET Core3.1

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

 

2、創建全局異常過濾器

在控制器里面創建一個異常過濾器,命名為ExceptionFilter.cs,過濾器繼承IExceptionFilter接口。

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

 異常過濾器,顧名思義,就是當程序發生異常時所使用的過濾器。用于在系統出現未捕獲異常時的處理。

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

 IExceptionFilter接口會要求實現OnException方法,當系統發生未捕獲異常時就會觸發這個方法。

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

系統一旦出現未捕獲異常后,比較常見的做法就是使用日志工具,將異常的詳細信息記錄下來,方便修正調試。

下面是日志記錄的實現:

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("
"));
                if (int.TryParse(lineNumberStr, out lineNumber))
                {

                }
            }

            #endregion

            #region 寫入信息到【數據庫】,這里自行入庫即可(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

            //下面是你的返回頁面顯示的內容提示,以下省略

        }
    }
}

 

3、依賴注入全局異常處理機制

Startup.cs里面把我們剛剛創建的全局異常處理機制注入到中間件來,放到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字符串轉換為int類型”,如下代碼,肯定是報錯的,我們來捕捉一下錯誤信息入庫。

var numberNo = "我是序列號";
//這里是轉換為int類型,然后數據源是string,肯定報錯,然后我們全局捕捉
//注意,我們這里沒有寫try catch
var number = Convert.ToInt32(numberNo);

運行項目后我們查詢一下數據庫,發現捕捉到錯誤信息了,包括

錯誤時間:2021-09-28 15:12:58.307

日志類型:error

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

錯誤的行號:36行,

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

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

下面是控制器方法截圖

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

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

到此這篇關于ASP.NET Core 中間件的使用之全局異常處理機制的文章就介紹到這了,更多相關ASP.NET Core 全局異常處理機制內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/xiongze520/p/15348130.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲一区视频 | 国产精品久久久久久久久免费高清 | 国产色在线| 精品欧美乱码久久久久久 | 免费午夜视频 | 中文字幕在线观看视频地址二 | 亚洲专区欧美 | 国产日韩一区二区 | 激情在线视频 | 亚洲欧美视频在线 | 亚洲午夜精品一区二区三区 | 国产色视频 | 日韩一二区 | 久久福利电影 | 直接看av的网站 | 亚洲成人一区二区 | av资源在线 | 成年人毛片在线观看 | 91视频在线播放视频 | 日韩电影免费在线观看中文字幕 | 久草观看 | www.天天操.com | 亚洲综合大片69999 | 日韩手机在线观看 | 日韩欧美视频 | 亚洲国产综合在线 | 久久久国产精品 | 99热在线播放 | 亚洲 中文 欧美 日韩 在线观看 | www.久草.com| 欧美日韩亚洲国产 | 国产精品毛片一区视频播不卡 | 久久久久久久av | 国产精品免费视频一区 | 国产91精品一区二区绿帽 | 欧美区亚洲区 | 久久久精品亚洲 | 久久久久久国产精品 | 日韩一区二区三区在线观看 | 久久爱电影 | 久久成|