asp.net(C#)网站发布后 Global.asax 里 Application_Error 不执行的问题

现象

在 Global.asax 用 Application_Error 捕捉了http的404,500等错误,在本机测试正常,发布后无效,几经周折终于解决了...

 

程序是这样设计的

Application_Error 捕捉到错误之后,记录错误信息,存放 /errorlog/ 目录里面,然后用RouteData设置控制器,跳转到错误提示页面,本机测试一切正常,发布之后不执行,网上查了好多资料

 

尝试过程

尝试过删除 PrecompiledApp.config 将 Global.asax 和Global.asax.cs直接复制到web文件夹...无效

尝试修改 iis7应用程序池的管道模式(集成/经典)  无效

 

尝试给 /errorlog/ 目录加上everyone权限 404的跳转成功,但是500依然无法跳转

尝试修改web.config在 <system.web> 加入 <customErrors mode="Off"/> 500跳转成功

 

结论

如果捕捉错误后需要记录日志文件,一定要给输出的文件夹加上写入权限,如果捕捉500之类的错误,一定要加<customErrors mode="Off"/>

Global.asax的执行与是否编译和ii7管道模式无关(至少我只写了http错误捕捉代码是无关的。)

记录一下备查

 

posted @ 2015-09-02 11:05  ssboy  阅读(1367)  评论(0编辑  收藏  举报