现象:刚开始只有一台服务器,前端请求时在header中添加了 tmp_token,后台也可以获取的到,完全没有问题。
但是后来由于项目的需要,又加了一台服务器,并用nginx 进行反向代理,结果发现tmp_token不能够发到后台。当时我就在本地装了一个nginx,把nginx的日志调到debug模式,结果发现了下面的提示:
client sent invalid header line: “tmp_token: 111” while reading client request headers
大概的意思就是 tmp_token 是无效的头信息。上网查了下,说在 nginx 的 http 模块下 添加一个参数即可:
参数如下:【underscores_in_headers on】
nginx默认是过滤掉了带有下划线的变量,如果需要添加带有下划线的请求头,需把 underscores_in_headers 设置为 on
当时我以为nginx的配置修改完了之后不需要重启就可以生效的,结果是 nginx的配置不重启不生效,费了半天劲。
重启了之后就好了。可以获取到header中带的 tmp_token的值。
修改了配置文件之后一定要记得重启nginx !!!
切记!!切记!!