ASP.NET的错误处理机制

 我来答
一袭可爱风1718
2022-10-23 · TA获得超过1.2万个赞
知道大有可为答主
回答量:6591
采纳率:99%
帮助的人:37.4万
展开全部

  对于一个Web应用程序来说 出错是在所难免的 因此我们应该未雨绸缪 为可能出现的错误提供恰当的处理 事实上 良好的错误处理机制正是衡量Web应用程序好坏的一个重要标准 试想一下 当用户不小心在浏览器输入了错误的URL或者当用户提供了一些信息导致程序出错的时候 如果我们没有对这些情况进行处理 而是任由 或是 的错误页面甚至出错的堆栈信息呈现在用户面前 这无疑会把一些用户给吓跑 所以 在我们开发Web应用程序的时候 应该对错误处理机制有充分的了解

  让我们回到ASP NET上来 先提两个问题让大家思考一下 ASP NET为我们提供了几种错误处理机制呢?如果同时采用了几种错误处理机制 它们之间是否存在一定的优先级呢?带着这个问题 我们先来看一下我们最常见的Web Config文件

  <?xml version= ?>   <configuration>   <system web>   <customErrors mode= On defaultRedirect= >   <error statusCode= redirect= />   <error statusCode= redirect= />   </customErrors>   </system web>   </configuration>

  对于<customErrors>这个设置项 我想无需多言了 详情可以参考MSDN的 第一种错误处理机制——使用Web Config的<customErrors>配置项应该是大家最常用的   接着 我们再看另外一个也很常用的文件 Global asax 提到这个文件 大家想到了什么呢?对 就是跟两大Web应用程序对象(Application Session)相关的事件了 在这些事件当中 有一个属于Application范畴的与错误相关的事件——Error 而对应的事件处理方法就是Application_Error了 顾名思义 这个事件处理方法在应用程序级别错误发生的时候就会被调用 因此你可以在这个方法中添加代码来对错误进行处理 如下所示

  protected void Application_Error(object sender EventArgs e) {   Exception objErr = Server GetLastError() GetBaseException();   Response Write( Error: + objErr Message);   Server ClearError();  }

  在这里 大家要注意最后一句代码的使用Server ClearError() 为什么要使用这句代码呢?如果不用又会怎样呢?在这里我又先卖个关子 好了 第二种错误处理机制——使用Global asax中的Application_Error事件处理方法也登台亮相了

  以上这两种错误处理方法都可以说是全局性的 一个源自应用程序配置文件 一个则是必须放在应用程序根目录下的Global asax文件的事件处理方法 与全局相对的就是局部 所以我们很自然的就会想 有没有应用于局部——某个页面的错误处理机制呢?答案是 有的 而且还有两种————使用ErrorPage属性以及使用Page_Error事件处理方法 对于第一种机制 你几乎可以在任何时候设置ErrorPage属性 从而确定页面发生错误的时候会重定向至哪个页面 对于第二种机制而言 它与Application_Error事件处理方法是很类似的 只不过被触发的时机不同而已 以下是具体的两个例子

  <script language= C# runat= server >   protected void Page_Load(object sender EventArgs e) {   this ErrorPage = ;

  }  </script>

  protected void Page_Error(object sender EventArgs e) {   Exception objErr = Server GetLastError() GetBaseException();   Response Write( Error: + objErr Message);   Server ClearError(); //同样要注意这句代码的使用  }

  至此 四种错误处理机制已经悉数登场 是时候给它们排个名次了 从优先级高到低排序 Page_Error事件处理方法 > ErrorPage属性 > Application_Error事件处理方法 > <customErrors>配置项 虽然排序是这样 但是这个排序之间又有微妙的关系 首先 要让ErrorPage属性能够发挥作用 <customErrors>配置项中的mode属性必须设为 On 其次 虽然Page_Error事件处理方法排在最前面 但是 如果少掉了Server ClearError()方法的话 仍然会引发优先级较低的错误处理 这种情况对于Application_Error事件处理方法也是如此 顺序是排好了 但是顺序却不是最重要的问题 甚至可以说是没有太多意义的问题 因为在很多情况下 你可能并不会混合使用这四种处理机制 我想 最重要的问题还是在如何选用这些错误处理机制上 对于这个问题 希望有经验的朋友能够谈谈看法

lishixinzhi/Article/program/net/201311/12225

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式