ASP.NET MVC中全局異常處理

之前不知道從哪裏找到的處理全局異常的,以爲蠻好用就記下來了。

1, 創建MyExecptionAttribute.cs類,寫入以下代碼:php

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Web;  
  5. using System.Web.Mvc;  
  6.   
  7. namespace Niunan.MVCShop.Code  
  8. {  
  9.     public class MyExecptionAttribute : HandleErrorAttribute  
  10.     {  
  11.         public static Queue<Exception> ExceptionQueue = new Queue<Exception>();//建立隊列.  
  12.   
  13.         public override void OnException(ExceptionContext filterContext)  
  14.         {  
  15.             //將異常信息入隊.  
  16.             ExceptionQueue.Enqueue(filterContext.Exception);//將異常信息入隊.  
  17.             //filterContext.HttpContext.Response.Redirect("/error.html");  
  18.             base.OnException(filterContext);  
  19.         }  
  20.     }  
  21. }  



2,在Global文件代碼以下:html

    1. using Niunan.Utility;  
    2. using System;  
    3. using System.Collections.Generic;  
    4. using System.Linq;  
    5. using System.Threading;  
    6. using System.Web;  
    7. using System.Web.Http;  
    8. using System.Web.Mvc;  
    9. using System.Web.Routing;  
    10.   
    11. namespace Niunan.MVCShop  
    12. {  
    13.     // 注意: 有關啓用 IIS6 或 IIS7 經典模式的說明,  
    14.     // 請訪問 http://go.microsoft.com/?LinkId=9394801  
    15.     public class MvcApplication : System.Web.HttpApplication  
    16.     {  
    17.         protected void Application_Start()  
    18.         {  
    19.             AreaRegistration.RegisterAllAreas();  
    20.   
    21.             WebApiConfig.Register(GlobalConfiguration.Configuration);   
    22.             RouteConfig.RegisterRoutes(RouteTable.Routes);  
    23.   
    24.             GlobalFilters.Filters.Add(new Code.MyExecptionAttribute()); //NET4創建的項目的話則是在APP_Stars/ConfigFilter.cs中  
    25.   
    26.             //經過線程開啓一個線程,而後不停的從隊列中或數據  
    27.             string filePath = Server.MapPath("/Log/");  
    28.             ThreadPool.QueueUserWorkItem(o =>  
    29.             {  
    30.                 while (true)  
    31.                 {  
    32.                     try  
    33.                     {  
    34.                         if (Code.MyExecptionAttribute.ExceptionQueue.Count > 0)  
    35.                         {  
    36.                             Exception ex = Code.MyExecptionAttribute.ExceptionQueue.Dequeue();//從隊列中拿出數據  
    37.   
    38.                             if (ex != null)  
    39.   
    40.                             {  
    41.                                 Tool.TxtLog(ex.ToString(), filePath + DateTime.Now.ToString("yyyyMMdd")+".txt");  
    42.                             }  
    43.                             else  
    44.                             {  
    45.                                 Thread.Sleep(30);  
    46.                             }  
    47.                         }  
    48.                         else  
    49.                         {  
    50.                             Thread.Sleep(30);//避免了CPU空轉。  
    51.                         }  
    52.                     }  
    53.                     catch (Exception ex)  
    54.                     {  
    55.                         Code.MyExecptionAttribute.ExceptionQueue.Enqueue(ex);  
    56.   
    57.                     }  
    58.                 }  
    59.   
    60.             }, filePath);  
    61.         }  
    62.     }  
    63. }  
相關文章
相關標籤/搜索