现象
在 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错误捕捉代码是无关的。)
记录一下备查