BUG记录-Java服务端获取不到请求头里的token

程序移植到生产环境发生了点问题,app反映token一直过期,我查了查放在请求头里的token没有获取到

String accessToken = request.getHeader(OAUTH_BEARER_TOKEN);

拉取服务器的日志

---------------
日志
-----
BaseController     : validateAccessToken2 fail :accessToken is null
---------------

很奇怪,也不是每次都获取不到,看了几遍,想到了几种办法(万能的百度)

嫌疑1:Nginx转发的服务请求头header中含有下划线的key,其值取不到的问题

-> access_token

nginx对header name的字符做了限制,默认 underscores_in_headers 为off,表示如果header name中包含下划线,则忽略掉

解决方法1:在nginx.conf中加上underscores_in_headers on配置,允许下划线

BUG记录-Java服务端获取不到请求头里的token_第1张图片

试了试,果然不行。

必须解决啊,其实是测试的手机不行,后来(改了后)换了几个手机都是正常的

解决方法2:不用下划线(算啦,能一方改动解决的就不麻烦第二方了)

你可能感兴趣的:(Java,Bug记录,java,nginx,android,token,liunx)