您的位置:首页 > 编程语言 > ASP

ASP.NET 中对于异常的处理

2009-06-12 00:47 204 查看
该篇文章是我于2009年6月10日通过自己编写的工具,批量从位于在博客园的博客站点(http://chenxizhang.cnblogs.com)同步而来。文章中的图片地址仍然是链接到博客园的。特此说明!

陈希章

原文地址:http://www.cnblogs.com/chenxizhang/archive/2008/11/12/1331777.html

原文标题:ASP.NET 中对于异常的处理

原文发表:2008/11/12 1:31:00

在ASP.NET编程中,如何对未捕获的异常进行统一的处理(或者称为响应),有两种方式
1. 通过Global.asax文件中编写Application_Error事件
private static string LOG_SOURCE = ConfigurationManager.AppSettings["Event Log Source"]; // If an exception is thrown in the application then log it to an event log
protected void Application_Error(object sender, EventArgs e) {
    Exception x = Server.GetLastError().GetBaseException();
    EventLog.WriteEntry(LOG_SOURCE, x.ToString(), EventLogEntryType.Error);
}    这个事件能捕获所有未处理的异常。一般在这里进行日志的记录(如果需要的话)   2.通过配置customError元素

这里的mode有三个可能性:On,Off,RemoteOnly。设置为On表示不管是在本地还是在远程访问都显示详细的错误消息,而不是Redirect到我们的页面去。Off则反之。而RemoteOnly则表示只有在远程的情况下才使用自定义错误页面
这样就可以,发生错误的时候,把用户导航到一个统一的页面。我们一般不需要(也最好不要)把错误的详细信息告诉用户。


 
 



需要注意一下,如果程序是在debug模式,那么以上都会失效。

所以,我们规定正式发布的程序都需要把调试模式关闭,这另外一方面还可以提高性能。
作者:陈希章

出处:http://blog.csdn.net/chen_xizhang

本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: