因为ios审核政策的问题,决定上线https,上线后遇到了这个问题。

用户登录后会跳转到登录后页面,由于经过了nginx,后端tomcat实际上被访问的是http协议,所以出现了 用 https://xxxx.com/login.do 的请求,登录后跳转到 http://xxx.com/aftlog.do 这样的情况。代码使用的是struts2 的 redirect方法。


解决方法如下:

      在tomcat的server.xml 的 connector 标签页里,增加 secure="true" scheme="https" proxyPort="443" 三个选项,直接重启tomcat即可。 


这样所有访问到tomcat的请求,如果使用struts的redirect方法,都会跳转成https的方法。如果有和我一样,因为历史版本使用了http,新版本使用了https,因为证书的原因,http和https的域名发生了变化,那就要求http和https都要可以用,往下看:


解决方法如下:

      在tomcat的server.xml配置文件中增加一个connector标签,内容和之前的一样即可,唯一的区别就是一个里面有https的三个参数,一个不带(这里要注意一下,2个connector的port不能一样,要不然端口冲突,tomcat起不来)。 这样,在前端配置nginx的时候,可以选择把来自http的请求转发到后端 不带https参数的connector 端口上, 把https的请求转发到带https参数的connector 端口上。


最后,建议在app版本更新多个之后取消http的connector,因为暂时还没有测试过增加一个connector对系统资源消耗有多大。