解决MVC3 服务器无法在已发送 HTTP 标头之后设置状态 问题

最近在查看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         }

搞定,世间清静了很多。  

posted @ 2013-04-03 14:33  yuan.net  阅读(2967)  评论(0编辑  收藏  举报