BUG记录-Java服务端获取不到请求头里的token
生活随笔
收集整理的這篇文章主要介紹了
BUG记录-Java服务端获取不到请求头里的token
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
程序移植到生產(chǎn)環(huán)境發(fā)生了點(diǎn)問題,app反映token一直過期,我查了查放在請(qǐng)求頭里的token沒有獲取到
String accessToken = request.getHeader(OAUTH_BEARER_TOKEN);拉取服務(wù)器的日志
--------------- 日志 ----- BaseController : validateAccessToken2 fail :accessToken is null ---------------很奇怪,也不是每次都獲取不到,看了幾遍,想到了幾種辦法(萬能的百度)
嫌疑1:Nginx轉(zhuǎn)發(fā)的服務(wù)請(qǐng)求頭header中含有下劃線的key,其值取不到的問題
->?access_token
nginx對(duì)header name的字符做了限制,默認(rèn) underscores_in_headers 為off,表示如果header name中包含下劃線,則忽略掉
解決方法1:在nginx.conf中加上underscores_in_headers on配置,允許下劃線
試了試,果然不行。
必須解決啊,其實(shí)是測(cè)試的手機(jī)不行,后來(改了后)換了幾個(gè)手機(jī)都是正常的
解決方法2:不用下劃線(算啦,能一方改動(dòng)解決的就不麻煩第二方了)
總結(jié)
以上是生活随笔為你收集整理的BUG记录-Java服务端获取不到请求头里的token的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 湖北职高考计算机本科多少分,2016年湖
- 下一篇: 基于Web的房地产乳霜营销平台