Nginx反向代理后无法获取header带下划线的头信息

HTTP请求header参数默认是不会丢失

分析原因:header请求参数,默认是可以支持下划线参数的,但是如果你用了nginx做反向代理,那么要注意nginx默认是不支持header有下划线的参数,会被直接丢弃

解决办法:

1.header参数,下划线参数都替换成不带下划线的参数

2.nginx增加配置(underscores_in_headers),即可支持header带下划线参数的传递,如下图

http {
    include       mime.types;
    default_type  application/octet-stream;
    # 运行带下划线参数传递
    underscores_in_headers on;
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';
 
    #access_log  logs/access.log  main;
 
    sendfile        on;
    #tcp_nopush     on;
 
    #keepalive_timeout  0;
    keepalive_timeout  65;
 
    #gzip  on;
    include conf.d/*.conf;
    server {
        listen       80;
        server_name  localhost;
        add_header 'Access-Control-Allow-Origin' '*';
        add_header 'Access-Control-Allow-Methods' 'PUT,POST,GET,DELETE,OPTIONS';
        add_header 'Access-Control-Allow-Headers' 'Content-Type,Content-Length, Authorization, Accept,X-Requested-With';
}

注:如果通过其他反向代理工具,也可能出现这个问题,都可以考虑是不是代理工具做了安全策略阻断

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Nginx用作反向代理时,有时可能会出现无法登录的情况。这可能是由于反向代理服务器不正确地处理了身份验证信息导致的。 首先,我们需要检查Nginx配置文件中的proxy_pass指令。确保将请求正确地转发到目标服务器。例如,如果您正在使用HTTPS,则需要将目标服务器的URL指定为https://而不是http://。 其次,我们需要检查是否正确地传递了身份验证信息。这可以在配置文件中使用proxy_set_header指令来完成。例如,如果目标服务器要求基本身份验证,则可以使用以下指令将用户名和密码传递给目标服务器: ``` location / { proxy_pass http://example.com; proxy_set_header Authorization "Basic base64encoded(username:password)"; } ``` 确保将“base64encoded(username:password)”替换为实际的用户名和密码的base64编码。 此外,还要确保Nginx服务器的时间正确设置,以避免与目标服务器之间的TLS/SSL握手问题。如果Nginx服务器和目标服务器的时间不同步,可能会导致TLS/SSL握手失败,从而导致无法登录。 最后,还要检查目标服务器的登录日志以查看是否有任何错误消息。这将有助于确定问题的具体原因。 通过检查以上几点,我们应该能够解决Nginx反向代理无法登录的问题。如果问题仍然存在,请查看Nginx和目标服务器的错误日志以获取更多详细信息,并尝试进行进一步的故障排除。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值