解决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         }

搞定,世间清静了很多。  

转载于:https://www.cnblogs.com/fangyuan303687320/archive/2013/04/03/2997882.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Access-Control-Allow-Origin头是HTTP响应中的一项标头,用于控制浏览器跨域资源共享(Cross-Origin Resource Sharing, CORS)的安全策略。当你在一个Web应用试图从其他源(通常非同源的)获取数据时,浏览器会检查这个头来确定是否允许请求。如果服务器设置了`Access-Control-Allow-Origin`,则指定的来源将被允许访问服务器资源。 要在服务器设置`Access-Control-Allow-Origin`,通常在处理HTTP请求的后端代码中,比如使用Node.js的Express框架,你可以在响应发送前添加这个头。这里是一个基本的例子: ```javascript // 假设你在Express中处理了一个GET请求 app.get('/api/data', function(req, res) { // 检查请求的Origin头 if (req.headers.origin) { // 允许特定或所有源 // 如果你想允许特定源,例如www.example.com res.setHeader('Access-Control-Allow-Origin', 'www.example.com'); // 或者允许所有源,但要谨慎,因为它可能带来安全风险 // res.setHeader('Access-Control-Allow-Origin', '*'); // 其他CORS相关的头也可以设置 res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS'); res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization'); // 如果请求是预检请求(OPTIONS),告知浏览器实际请求方法是允许的 if (req.method === 'OPTIONS') { res.status(204).end(); } else { // 正常响应数据 res.send({ your_data: 'here' }); } } else { // 如果没有Origin头,拒绝请求 res.status(403).send({ error: 'CORS request requires an Origin header' }); } }); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值