解决nginx https代理tomcat redirect问题

问题描述

http服务器:nginx,10.10.10.95,版本:1.10.1,请求使用协议为https,端口为18080。

服务服务器:tomcat,10.10.10.92,使用协议为http,端口为8080。

问题:当在业务服务器使用sendRedirect时,tomcat响应302给nginx,nginx再响应给浏览器,默认情况下,nginx响应给浏览器的location会将schema换为http,端口为:80。

这就导致浏览器redirect后,访问不到正确资源。


过程举例:

  1. 浏览器输入:https://10.10.10.95:18080/redirect_test.do
  2. redirect_test.do中执行sendRedirect("/welcome.do")
  3. 浏览器接收到的redirect响应(302)中location为http://10.10.10.95/welcome.do
  4. 浏览器跳到http://10.10.10.95/welcome.do,发现访问不了


解决方案

修改nginx配置,关键配置如下:


    server{
        listen 18080;
        server_name ecsc;
        ssl on;
        ssl_certificate  /root/ssl/test.crt;
        ssl_certificate_key  /root/ssl/test_nopass.key;
        error_page 497  https://$host:8080;

        access_log  /var/log/nginx/access.log  main;

        proxy_redirect http:// $scheme://;
        port_in_redirect on;


        location ~/druid{
                return 404;
        }

        location /{
                proxy_connect_timeout 300;
                proxy_send_timeout 300;  
                proxy_read_timeout 300;
                expires 10d;
                proxy_pass  http://console.eayun.com ;
                proxy_set_header Host $host:$server_port;
                proxy_set_header  X-Real-IP        $remote_addr;  
                proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;
                proxy_set_header X-NginX-Proxy true;
        }


说明:

使用proxy_redirect将location中的协议转换为请求nginx的协议。

使用port_in_redirect on指示nginx使用请求的端口,而不是使用默认端口。

proxy_set_header Host $host:$server_port;很关键,我也不明白为啥大笑,不设置,端口为变为80。


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值