风平浪静的下午,一个前端开发同事找到我,说感觉好像nginx那边有一些转发并没有到达后端。
我问,怎么了?
她说的也非常具体,第一是常规访问服务,然后返回的状态是401,提示令牌失效(Token Invalid
)。接着直接访问后端所代理的服务,然后就是正常的。
哦,听上去很明显啦,事儿就是到nginx这里卡住了呗。我问她详细的情况是怎样的?
她说获取验证码以及登陆都是没有问题的,但是就是这里的token没有传过去,token是放在请求头里边的,这个头的名称是“old_token
”。
听上去一切好像都没什么问题,而这个问题也确实是我第一次遇到的,后来求助百度,在某篇文章里找到了答案,这里粘贴过来,以存记录。
于是想到两个环境的不同之处在于线上是通过nginx做的代理转发,会不会是nginx搞的鬼?于是搜索“nginx request header 丢失”,果不其然是这个问题,nginx对下划线的头信息做了限制,找到问题所在就等于完成了一大半,办法总比困难多。遂决定记录之。
old_token
”改成”old-token
“就可以了。(难怪一般header的name都是’-‘来拼接的,比如”User-Agent”) 。解决方法是:在nginx里的nginx.conf配置文件中的http部分中添加如下配置:
underscores_in_headers on;
默认 underscores_in_headers 为off
。
我们采取了第一种方法,她更改了一下请求头的名称,果然这个问题就解决了。
参考链接:https://blog.csdn.net/Nazir2513/article/details/70889319
© 2018 www.qingketang.net 鄂ICP备18027844号-1
武汉快勤科技有限公司 13554402156 武汉市东湖新技术开发区关山二路特一号国际企业中心6幢4层7号
扫码关注,全站教程免费播放
订单金额:
支付金额:
支付方式: