logo头像

技术是一种信念

https经过nginx后struts跳转成http

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

1
2
3
<action name="login_*" method="{1}" class="loginAction">
<result name="nextjsp" type="redirect">/skin/main/main.jsp</result>
</action>
  • 系统只用https访问

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

1
2
3
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8449" URIEncoding="UTF-8" secure="true" scheme="https" proxyPort="443" />

这样所有访问到tomcat的请求,如果使用struts的redirect方法,都会跳转成https的方法。

  • 两种方式都可以访问

如果项目有特殊要求,需要项目既可以使用http也可以使用https访问,可以采用如下的方法:

​ 在tomcat的server.xml配置文件中增加一个connector标签,内容和之前的一样即可,唯一的区别就是一个里面有https的三个参数,一个不带(这里要注意一下,2个connector的port不能一样,要不然端口冲突,tomcat起不来)。

1
2
3
4
5
6
 <Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8449" URIEncoding="UTF-8" />
<Connector port="8881" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8449" URIEncoding="UTF-8" secure="true" scheme="https" proxyPort="443" />

在前端配置nginx的时候,可以选择把来自http的请求转发到后端 不带https参数的connector 端口上, 把https的请求转发到带https参数的connector 端口上。