实现的功能很简单,就是用企业库的异常处理模块和日志模块,利用windows的系统日志,记录web应 用的异常。
我的企业库是4.1版
1.添加对Microsoft.Practices.EnterpriseLibrary.ExceptionHandling和 Microsoft.Practices.EnterpriseLibrary.Logging的引用
2.重写Application_Error
protected void Application_Error(Object sender, EventArgs e)
{
try {
Exception objErr = Server.GetLastError ().GetBaseException();
Application["errorPage"] = Request.Url.ToString();
Application["errorMsg"] = objErr.Message;
Server.ClearError();
ExceptionPolicy.HandleException(objErr, "global expcetion"); //第一个参数是异常,第二个可以理解为异常名或者异常类型
}
catch
{ }
}
3.在配置文件中加入
<exceptionHandling>
<exceptionPolicies>
<add name="global expcetion"> //这就是你定义的异常名或者异常类型
<exceptionTypes>
<add type="System.Exception, mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
postHandlingAction="NotifyRethrow" name="Exception">
<exceptionHandlers>
<add logCategory="General" eventId="100" severity="Error" title="Enterprise Library Exception Handling"
formatterType="Microsoft.Practices.EnterpriseLibrary.ExceptionHandling.TextExceptionFormatte r, Microsoft.Practices.EnterpriseLibrary.ExceptionHandling, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
priority="0" useDefaultLogger="false" type="Microsoft.Practices.EnterpriseLibrary.ExceptionHandling.Logging.LoggingExceptionHandle r, Microsoft.Practices.EnterpriseLibrary.ExceptionHandling.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
name="Logging Handler" />
</exceptionHandlers>
</add>
</exceptionTypes>
</add>
</exceptionPolicies>
</exceptionHandling>
4.在程序中加入下列代码测试异常
throw new Exception("Test");
5.注意:
需要将异常抛至全局处理的action,不要加异常过滤器IExceptionFilter,否则的话,异常无法传递 到Application_Error。
如果一定要使用IExceptionFilter,则将ExceptionPolicy.HandleException(objErr, "global expcetion"); 加入至过滤器中即可.