這篇文章主要講解了“asp.net開發(fā)中常見的公共捕獲異常方式有哪些”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“asp.net開發(fā)中常見的公共捕獲異常方式有哪些”吧!

1、BasePage類處理方式
在頁面的公共基類里重寫OnError事件。在前面這篇《asp.net實(shí)現(xiàn)非常實(shí)用的自定義頁面基類》里,樓豬已經(jīng)貼了代碼,就不再費(fèi)事了。根據(jù)經(jīng)驗(yàn),很多人開發(fā)的時(shí)候幾乎都這么寫,而且對(duì)調(diào)試和維護(hù)還是很有幫助的。需要說明的是,每新添一個(gè)頁面,其對(duì)應(yīng)類都必須繼承自BasePage類異常處理才起作用。
2、Global.asax處理方式
如1中所述,BasePage類的異常處理要求每一個(gè)aspx類文件都繼承它,適用性和性能顯然會(huì)打折扣。而Global.asax文件定義了asp.net應(yīng)用程序中的所有應(yīng)用程序?qū)ο蠊灿械姆椒ā傩院褪录覀兛梢圆徊捎肂asePage的處理方式,在Global.asax里實(shí)現(xiàn)Application_Error事件并處理也可以。下面模仿BasePage類里的處理異常方法,實(shí)現(xiàn)如下:
/// <summary>
/// 出錯(cuò)處理:寫日志,導(dǎo)航到公共出錯(cuò)頁面
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Application_Error(object sender, EventArgs e)
{
if (Server.GetLastError() == null) return;
Exception ex = Server.GetLastError().GetBaseException();
string error = this.DealException(ex);
DotNet.Common.Util.Logger.WriteFileLog(error, HttpContext.Current.Request.PhysicalApplicationPath + "LogFile");
if (ex.InnerException != null)
{
error = this.DealException(ex);
DotNet.Common.Util.Logger.WriteFileLog(error, HttpContext.Current.Request.PhysicalApplicationPath + "LogFile");
}
this.Server.ClearError();
this.Response.Redirect("/Error.aspx");
}
/// <summary>
/// 處理異常,用來將主要異常信息寫入文本日志
/// </summary>
/// <param name="ex"></param>
/// <returns></returns>
private string DealException(Exception ex)
{
this.Application["StackTrace"] = ex.StackTrace;
this.Application["MessageError"] = ex.Message;
this.Application["SourceError"] = ex.Source;
this.Application["TargetSite"] = ex.TargetSite.ToString();
string error = string.Format("URl:{0}\n引發(fā)異常的方法:{1}\n錯(cuò)誤信息:{2}\n錯(cuò)誤堆棧:{3}\n",
this.Request.RawUrl, ex.TargetSite, ex.Message, ex.StackTrace);
return error;
}上面方式的好處是,寫一次代碼,應(yīng)用程序發(fā)生的大部分異常它都給你捕捉處理了。樓豬要在這里由衷地發(fā)一番感慨,感謝ms為我們提供了這么優(yōu)秀的框架,太省事了吧。
3、IHttpModule接口處理
1和2的處理方式大家都是非常熟悉的,樓豬在實(shí)際開發(fā)中基本上都是遵循上面兩種寫法,而且樓豬因?yàn)橛辛?中這種大小通吃的處理方式,甚至已經(jīng)激動(dòng)地感謝ms了。但是,在asp.net程序調(diào)用線程進(jìn)行異步處理的時(shí)候,容易發(fā)生在后臺(tái)線程或線程池里拋出的異常并不能被1或(和)2完全捕捉到,這就涉及到asp.net下未捕獲異常的處理。也就是說樓豬以前做過的很多大小項(xiàng)目中對(duì)異常的處理是不完備的。這難道是nc樓豬沒有先謝國家種下的惡果嗎?感謝國家,感謝ms,感謝博客園,感謝無私的xdjm,感謝自己......
asp.net下未捕獲異常的處理步驟如下:
(1)、創(chuàng)建一個(gè)實(shí)現(xiàn)IHttpModule接口的類
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Text;
namespace DotNet.Common.WebForm
{
using DotNet.Common.Util;
/// <summary>
/// 通用未捕獲異常處理
/// </summary>
public class AspNetUnhandledExceptionModule : IHttpModule
{
static object syncObj = new object();
static bool isInit = false;
public AspNetUnhandledExceptionModule()
{
}
#region IHttpModule Methods
public void Init(HttpApplication context)
{
lock (syncObj)
{
if (!isInit)
{
AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(OnUnhandledException);
isInit = true;
}
}
}
public void Dispose()
{
}
#endregion
#region OnUnhandledException
void OnUnhandledException(object o, UnhandledExceptionEventArgs e)
{
if (e.ExceptionObject == null) return;
Exception ex = e.ExceptionObject as Exception;
string error = string.Format("引發(fā)異常的方法:{0}\n錯(cuò)誤信息:{1}\n錯(cuò)誤堆棧:{2}\n",
ex.TargetSite, ex.Message, ex.StackTrace);
Logger.WriteFileLog(error, AppDomain.CurrentDomain.BaseDirectory + "LogFile");
}
#endregion
}
}(2)、web.config節(jié)點(diǎn)配置
<httpModules> <add name="AspNetUnhandledExceptionModule" type="DotNet.Common.WebForm.AspNetUnhandledExceptionModule, DotNet.Common.WebForm"></add> </httpModules>
最后貼出測試代碼:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
System.Threading.ThreadPool.QueueUserWorkItem(new System.Threading.WaitCallback(Test), null);
}
}
protected void Test(object state)
{
int[] numArr = new int[100];
numArr[100] = 100; //異常
}需要說明的是,通過線程或者線程池處理的程序,在發(fā)生異常時(shí),每個(gè)線程都會(huì)有它自己獨(dú)立的上下文,所以HttpContext對(duì)象應(yīng)盡可能少地出現(xiàn)在異常處理階段。
感謝各位的閱讀,以上就是“asp.net開發(fā)中常見的公共捕獲異常方式有哪些”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)asp.net開發(fā)中常見的公共捕獲異常方式有哪些這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
網(wǎng)頁名稱:asp.net開發(fā)中常見的公共捕獲異常方式有哪些-創(chuàng)新互聯(lián)
分享URL:http://chinadenli.net/article6/coggig.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、網(wǎng)站設(shè)計(jì)、外貿(mào)建站、品牌網(wǎng)站建設(shè)、云服務(wù)器、小程序開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容