分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow
也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!
最近在查看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 }
搞定,世间清静了很多。
<script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>