《跟我学Shiro》笔记14-SSL

  1. 生成数字证书
  2. 设置 tomcat
  3. 添加 SSL 到配置文件
  4. 使用 Maven Jetty 插件

原文地址:第十四章 SSL——《跟我学Shiro》
目录贴: 跟我学Shiro目录贴
源码:https://github.com/zhangkaitao/shiro-example

对于 SSL 的支持,Shiro 只是判断当前 url 是否需要 SSL 登录,如果需要自动重定向到 https 进行访问。

生成数字证书

使用 JDKkeytool 命令,生成证书(包含证书/公钥/私钥)到 D:\localhost.keystore

keytool -genkey -keystore "D:\localhost.keystore" -alias localhost -keyalg RSA

设置 tomcat

此处使用了 apache-tomcat-7.0.40 版本,打开 conf/server.xml,加上:

<Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
       maxThreads="150" scheme="https" secure="true"
       clientAuth="false" sslProtocol="TLS"
       keystoreFile="D:\localhost.keystore" keystorePass="123456"/> <!-- 生成 keystore 时设置的密码 -->

添加 SSL 到配置文件

<bean id="sslFilter" class="org.apache.shiro.web.filter.authz.SslFilter">
    <property name="port" value="8443"/> <!-- 默认端口是 443,此处使用了 8443 -->
</bean>
<bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">
    <!-- …… -->
    <property name="filters">
        <util:map>
            <entry key="authc" value-ref="formAuthenticationFilter"/>
            <entry key="ssl" value-ref="sslFilter"/>
        </util:map>
    </property>
    <property name="filterChainDefinitions">
        <value>
            /login.jsp = ssl,authc <!-- 表示访问登录页面时需要走 SSL -->
            /logout = logout
            /authenticated.jsp = authc
            /** = user
        </value>
    </property>
</bean>

使用 Maven Jetty 插件

如果使用 Maven Jetty 插件,可以直接如下插件配置:

<plugin>
   <groupId>org.mortbay.jetty</groupId>
   <artifactId>jetty-maven-plugin</artifactId>
   <version>8.1.8.v20121106</version>
   <configuration>
     <webAppConfig>
       <contextPath>/${project.build.finalName}</contextPath>
     </webAppConfig>
     <connectors>
     <connector implementation="org.eclipse.jetty.server.nio.SelectChannelConnector">
       <port>8080</port>
     </connector>
     <connector implementation="org.eclipse.jetty.server.ssl.SslSocketConnector">
       <port>8443</port>
       <keystore>${project.basedir}/localhost.keystore</keystore>
       <password>123456</password>
       <keyPassword>123456</keyPassword>
     </connector>
     </connectors>
   </configuration>
</plugin>

转载请注明来源,欢迎对文章中的引用来源进行考证,欢迎指出任何有错误或不够清晰的表达。可以在下面评论区评论,也可以邮件至 bin07280@qq.com

文章标题:《跟我学Shiro》笔记14-SSL

文章字数:498

本文作者:Bin

发布时间:2018-04-19, 20:12:22

最后更新:2019-09-03, 16:46:23

原始链接:http://coolview.github.io/2018/04/19/%E8%B7%9F%E6%88%91%E5%AD%A6Shiro/%E3%80%8A%E8%B7%9F%E6%88%91%E5%AD%A6Shiro%E3%80%8B%E7%AC%94%E8%AE%B014-SSL/

版权声明: "署名-非商用-相同方式共享 4.0" 转载请保留原文链接及作者。

目录