程序移植到生产环境发生了点问题,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配置,允许下划线
试了试,
果然不行。必须解决啊,其实是测试的手机不行,后来(改了后)换了几个手机都是正常的
解决方法2:不用下划线(算啦,能一方改动解决的就不麻烦第二方了)
BUG记录-Java服务端获取不到请求头里的token
最新推荐文章于 2024-05-29 15:10:24 发布