Request header field Access-Control-Allow-Headers is not allowed by Access-Control-Allow-Headers

   最近在用thinkPHP和Angular开发一个小系统。后台已经解决跨域问题了,但是前端这边还没有搞定这个问题。一直报错,错误是:Request header field Access-Control-Allow-Headers is not allowed by Access-Control-Allow-Headers

   当我在前端(Angular4)设置header,这个问题就会消失。

    

    但是,却发现另外一个问题。每次我发送一次请求,请求会执行两次。


   根据网上资料显示,OPTIONS请求可以说是一个“预请求”,用于探测发起请求的一方是否可以访问服务器,这就是跨域问题的表现之一。感觉前后端都已经解决跨域了,还是没解决这个问题。后来到stackoverflow找答案,终于找到了解决的办法。就是把header的'Content-Type'的值改为

 headers.set('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');

   根据stackoverflow的答案的说法是:Angular发起请求的header的'Content-Type'的值默认为'application/json',每次发送请求,会尝试先发送一次OPTIONS请求,所以我们要重写Content-Type的值。

      stackoverflow 问题的链接:https://stackoverflow.com/questions/25727306/request-header-field-access-control-allow-headers-is-not-allowed-by-access-contr

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值