ASP.NET MVC中錯誤日誌信息記錄

来源:http://www.cnblogs.com/wei325/archive/2016/04/29/5433288.html
-Advertisement-
Play Games

MVC中有一個處理異常的過濾器 HandleErrorAttribute 1.新建一個類繼承自 HandleErrorAttribute,然後重寫OnException這個方法 只要程式出錯就會執行這個方法。 2.註冊定義好的異常過慮器 打開App_Start文件夾中FilterConfig.cs修 ...


MVC中有一個處理異常的過濾器 HandleErrorAttribute

1.新建一個類繼承自 HandleErrorAttribute,然後重寫OnException這個方法

public class MyExceptionAttribute:HandleErrorAttribute
    {
        /// <summary>
        /// 可捕獲異常數據
        /// </summary>
        /// <param name="filterContext"></param>
        public override void OnException(ExceptionContext filterContext)
        {
            base.OnException(filterContext);
            Exception ex = filterContext.Exception;
            //把錯誤信息寫進隊列
        }
    }

只要程式出錯就會執行這個方法。

2.註冊定義好的異常過慮器

打開App_Start文件夾中FilterConfig.cs修改

 public static void RegisterGlobalFilters(GlobalFilterCollection filters)
        {
            //filters.Add(new HandleErrorAttribute());
            filters.Add(new MyExceptionAttribute());
        }

 

驗證一下:在1中定義的過慮器的ex行打一個斷點,然後在控制器的action中增加一段出錯的代碼

 public ActionResult Index()
        {
            int a = Convert.ToInt16("aaa");
            return Content(a.ToString());
           // return View();
        }

運行可以看到效果:

 

3.把錯誤信息存到隊列中

因為直接把錯誤寫到日誌會出現多個人同時操作日誌文件,會造成併發的問題,所以把錯誤存到隊列,然後從隊列中把數據記錄到文件中不會造成併發,修改過慮器。

public class MyExceptionAttribute:HandleErrorAttribute
    {
        //創建一個隊列
        public static Queue<Exception> execptionQueue = new Queue<Exception>();
        /// <summary>
        /// 可捕獲異常數據
        /// </summary>
        /// <param name="filterContext"></param>
        public override void OnException(ExceptionContext filterContext)
        {
            base.OnException(filterContext);
            Exception ex = filterContext.Exception;
            //把錯誤信息寫進隊列
            execptionQueue.Enqueue(ex);
            //跳轉到錯誤頁
            filterContext.HttpContext.Response.Redirect("/Error.html");
        }
    }

4.開啟一個新的線程不斷的讀取隊列,把消息寫入日誌文件

讀取消息應該在程式開始的時候就開始執行,在Global.asax.cs中添加代碼

 protected void Application_Start()
        {
            AreaRegistration.RegisterAllAreas();

            WebApiConfig.Register(GlobalConfiguration.Configuration);
            FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
            RouteConfig.RegisterRoutes(RouteTable.Routes);
            BundleConfig.RegisterBundles(BundleTable.Bundles);
            string filePath = Server.MapPath("/Log/");
            ThreadPool.QueueUserWorkItem((a) => {
                while (true)
                {
                    //判斷一下隊列中是否有數據
                    if (MyExceptionAttribute.execptionQueue.Count > 0)
                    {
                        //出隊
                        Exception ex = MyExceptionAttribute.execptionQueue.Dequeue();
                        if (ex != null)
                        {
                            //將異常信息寫到日誌文件中
                            string fileName = DateTime.Now.ToString("yyyy-MM-dd");
                            File.AppendAllText(filePath + fileName + ".txt", ex.ToString(), System.Text.Encoding.UTF8);
                        }
                        else
                        {
                            //如果隊列中沒有數據,休息5秒鐘
                            Thread.Sleep(5000);
                        }
                    }
                    else
                    {
                        //如果隊列中沒有數據,休息
                        Thread.Sleep(5000);
                    }
                }
            });
        }

完成,執行一條出錯語句,Log文件夾下就多了一個記錄錯誤日誌的文件了。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近使用Winform做一個小系統,由於需要保存一些預設配置項。自然就想到了輕量級的配置文件類型ini。在此也分享和記錄一下實現方式,方便以後查詢和使用。 廢話不多說上代碼: 實現公共函數↓ 調用實例↓ 初始化判斷是否存在配置,否則創建文件↓ ...
  • 首先實體是: using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.Linq; using System.Web; namespace Pag ...
  • 學C#也有兩年多了,發現如果不總結一下,很多C#的知識都會忘掉,所以希望寫這系列的文章來總結一下C#的基礎知識。如果有寫錯或者不足的地方,希望可以提出糾正。 C#可以說是依附在.NET Framework 框架的編程語言,當然,你可以用來寫Unity3D腳本也是可以的。C#的.NET Framewo ...
  • 轉自:http://holysonll.blog.163.com/blog/static/2141390932013411112823855/ document.ready和onload的區別——JavaScript文檔載入完成事件 頁面載入完成有兩種事件 一是ready,表示文檔結構已經載入完成( ...
  • 前記:好吧好吧,我好好的自我檢討,這個總結拖了這麼久才來寫,而且一周多沒有看技術相關的東西,實在罪過,不過因為想做的事情太多,所以時間的分配確實是一個很嚴肅的問題,不是時間不夠用,是我自己沒有做好時間管理,五一之後的分配重心又回歸技術的學習,但是寫小說、學英語也不能放下,所以時間安排就更重要了,an ...
  • 使用WinForm實現了圖片base64編碼解碼的效果圖:示例base 64編碼字元串: 代碼如下: 轉自:http://hovertree.com/h/bjaf/wa5nbd3w.htm 參考:http://hovertree.com/h/bjaf/mdklgyjr.htm 更多:http://w ...
  • 一般我們寫好實體之後,配置好數據上下文對象,還有在配置文件中改好連接字元串之後。 還不能生成資料庫,自動生成資料庫,有兩步關鍵步驟: 1. Enable Migrations 2. Update-database 執行玩第二步之後,就自動生成了資料庫。 實例 //實體: using System; ...
  • [re: Orchard CMS] This caused me scratching my head for days and now I can even feel it's bleeding. The answer however is the simplest. Because it's n ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...