最近在查看yifen.com网站的运行日志,发现每天都有好几M的日志文件,里面都是同样的错误如下:
2013-04-03 14:03:30,397 [13] ERROR Quan.Com.Controllers.CustomeExceptionAttribute [(null)] <(null)> - 发生时间:04/03/2013 14:03:30 发生异常页: http://www.yifen.com/memberinfo/ViewMyQuan/ 异常信息: 服务器无法在已发送 HTTP 标头之后设置状态。 错误源:System.Web 堆栈信息: 在 System.Web.HttpResponse.set_StatusCode(Int32 value) 在 System.Web.Mvc.HttpStatusCodeResult.ExecuteResult(ControllerContext context) 在 System.Web.Mvc.ControllerActionInvoker.InvokeAction(ControllerContext controllerContext, String actionName) --------------------------------------<br> 2013-04-03 14:03:30,453 [13] ERROR Quan.Com.Controllers.CustomeExceptionAttribute [(null)] <(null)> - 出错者IP:115.236.163.194
由于一开始就是学的MVC3,在之前也没有相关处理经验,网上查了很多资料都只是讲应该在请求发送到流之前做如下处理:
Response.BufferOutput = true;
我在每一处跳转的地方 都加上,但问题依旧
Response.BufferOutput = true; return Redirect("/member/logon");
这个问题其实不会影响网站的运行,代码执行后客户端会跳转成功,但是每次在查看网站运行状态的时候,都会看到如天书的异常信息,实在很烦
既然服务器已经在输出HTTP标头,那么我可不可以把这个标头信息都清除,然后重新设置呢,想到这里,我改进了一下代码并封装了一个方法以后备用
1 public void RedirectUrl(string url) 2 { 3 this.Response.Clear();//这里是关键,清除在返回前已经设置好的标头信息,这样后面的跳转才不会报错 4 this.Response.BufferOutput = true;//设置输出缓冲 5 if (!this.Response.IsRequestBeingRedirected)//在跳转之前做判断,防止重复 6 { 7 this.Response.Redirect(url, true); 8 } 9 }
搞定,世间清静了很多。