今天在开发过程中遇到一个很奇特的问题,就是 Global 文件中的Application_Error 方法不执行的问题,很是苦恼,查了有关这方面的问题,感觉网友们回答的都有点乱,有些人说 在编译时不需要这个文件,在项目部署的时候再放进去,有些人说Global.asax可能没被正常加载,session没有启用引起Application_Error内部出错,等等
最开始,我也以为是 Global.asax 文件没被加载,所以我在Application_Start 方法中设置断点,发现 是可以进入的,这就排除了加载失败的可能性,
后来我在测试过程中意外的发现在webform 页面的 的Load事件中 编写一段会抛出异常的代码,例如:(string str = "a" int.parse(str)),然后在Application_Error 中是可以进入的,这就奇怪了,难道Global文件只在WebForm页面中才有效?这应该不可能啊,
因为我们得项目用的是html 页面 后台使用的是ashx(一般处理程序)里面, 所以我就在想是不是异常要在 一般处理程序里面去处理,我们的一般处理程序结构如图:
我们在接受了请求后,响应之前是使用了try{}catch语句的,也就是捕获了异常,但是并没有处理异常,我就试了试加上throw ex;这句话在catch中,果然,问题解决了
解释一下红色框部分:原本关注Global 的Application_Error方法就是为了 给系统记录日志,红色框中代码就是给数据库中添加一条捕获的异常的日志信息,这里这部分可以写在Global 的Application_Error方法中,同时替换这部分为 throw ex;这句话
和我现在这样写的结果都可以满足我们项目的需求。
其实简单的结论就是:全局Global文件 的Application_Error 是在抛出异常的情况下才会执行的,也就是说,当出现异常时,你捕获了,但是不处理就不会进入该方法,反之继续往上抛出 最终会进入该方法!