SSL——Secure Sockets Layer


双向认证(个人理解):
客户端认证:
客户端通过浏览器访问某一网站时,如果该网站为HTTPS网站,浏览器会自动检测系统中是否存在该网站的信任证书,如果没有信任证书,浏览器一般会拒绝访问,IE会有一个继续访问的链接,但地址栏是红色,给予用户警示作用,即客户端验证服务端并不是强制性的,可以没有服务端的信任证书,当然是否继续访问完全取决于用户自己。如何去除地址栏的红色警告呢?后续会介绍导入服务端证书到浏览器的方法。

服务端认证:
服务端需要获取到客户端通过浏览器发送过来的认证证书,该证书在服务端的证书库中已存在,仅仅是个匹配过程,匹配成功即通过认证,可继续访问网站资源,反之则无法显示网页,后续有截图。

基本逻辑:
1、生成服务端密钥库并导出证书;
2、生成客户端密钥库并导出证书;
3、根据服务端密钥库生成客户端信任的证书;
4、将客户端证书导入服务端密钥库;
5、将服务端证书导入浏览器。

构建演示系统
演示环境:
JDK:1.6.0_32
Tomcat:apache-tomcat-7.0.27
开发工具:MyEclipse 10
浏览器:Internet Explorer 9

一、生成密钥库和证书
可参考以下密钥生成脚本,根据实际情况做必要的修改,其中需要注意的是:服务端的密钥库参数“CN”必须与服务端的IP地址相同,否则会报错,客户端的任意。
key.script
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl1、生成服务器证书库
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslkeytool -validity 365 -genkey -v -alias server -keyalg RSA -keystore E:\ssl\server.keystore -dname "CN=127.0.0.1,OU=icesoft,O=icesoft,L=Haidian,ST=Beijing,c=cn" -storepass 123456 -keypass 123456
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl2、生成客户端证书库
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslkeytool -validity 365 -genkeypair -v -alias client -keyalg RSA -storetype PKCS12 -keystore E:\ssl\client.p12 -dname "CN=client,OU=icesoft,O=icesoft,L=Haidian,ST=Beijing,c=cn" -storepass 123456 -keypass 123456
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl3、从客户端证书库中导出客户端证书
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslkeytool -export -v -alias client -keystore E:\ssl\client.p12 -storetype PKCS12 -storepass 123456 -rfc -file E:\ssl\client.cer
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl4、从服务器证书库中导出服务器证书
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslkeytool -export -v -alias server -keystore E:\ssl\server.keystore -storepass 123456 -rfc -file E:\ssl\server.cer
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl5、生成客户端信任证书库(由服务端证书生成的证书库)
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslkeytool -import -v -alias server -file E:\ssl\server.cer -keystore E:\ssl\client.truststore -storepass 123456
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl6、将客户端证书导入到服务器证书库(使得服务器信任客户端证书)
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslkeytool -import -v -alias client -file E:\ssl\client.cer -keystore E:\ssl\server.keystore -storepass 123456
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl7、查看证书库中的全部证书
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslkeytool -list -keystore E:\ssl\server.keystore -storepass 123456


二、Tomat配置
使用文本编辑器编辑${catalina.base}/conf/server.xml
找到Connector port="8443"的标签,取消注释,并修改成如下:
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol" SSLEnabled="true"
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl               maxThreads="150" scheme="https" secure="true"
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl               clientAuth="true" sslProtocol="TLS"
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl               keystoreFile="${catalina.base}/key/server.keystore" keystorePass="123456"
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl               truststoreFile="${catalina.base}/key/server.keystore" truststorePass="123456"/>

备注:
keystoreFile:指定服务器密钥库,可以配置成绝对路径,如“D:/key/server.keystore”,本例中是在Tomcat目录中创建了一个名称为key的文件夹,仅供参考。
keystorePass:密钥库生成时的密码
truststoreFile:受信任密钥库,和密钥库相同即可
truststorePass:受信任密钥库密码

三、建立演示项目
项目结构图:
项目名称:SSL(随意)
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_39

SSLServlet.java
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslpackage com.icesoft.servlet;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslimport java.io.IOException;
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslimport java.io.PrintWriter;
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslimport java.security.cert.X509Certificate;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslimport javax.servlet.ServletException;
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslimport javax.servlet.http.HttpServlet;
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslimport javax.servlet.http.HttpServletRequest;
Java Tomcat SSL 服务端/客户端双向认证(一)_java sslimport javax.servlet.http.HttpServletResponse;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_51/**
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52 * <p>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52 * SSL Servlet
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52 * </p>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52 * 
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52 * @author IceWee
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52 * @date 2012-6-4
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52 * @version 1.0
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_59 */
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_60public class SSLServlet extends HttpServlet {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    private static final long serialVersionUID = 1601507150278487538L;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    private static final String ATTR_CER = "javax.servlet.request.X509Certificate";
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    private static final String CONTENT_TYPE = "text/plain;charset=UTF-8";
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    private static final String DEFAULT_ENCODING = "UTF-8";
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    private static final String SCHEME_HTTPS = "https";
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    public void doGet(HttpServletRequest request, HttpServletResponse response)
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_69            throws ServletException, IOException {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        response.setContentType(CONTENT_TYPE);
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        response.setCharacterEncoding(DEFAULT_ENCODING);
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        PrintWriter out = response.getWriter();
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        X509Certificate[] certs = (X509Certificate[]) request.getAttribute(ATTR_CER);
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_74        if (certs != null) {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52            int count = certs.length;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52            out.println("共检测到[" + count + "]个客户端证书Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_77");
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_78            for (int i = 0; i < count; i++) {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52                out.println("客户端证书 [" + (++i) + "]: ");
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52                out.println("校验结果:" + verifyCertificate(certs[--i]));
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52                out.println("证书详细:\r" + certs[i].toString());
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82            }
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_83        } else {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_84            if (SCHEME_HTTPS.equalsIgnoreCase(request.getScheme())) {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52                out.println("这是一个HTTPS请求,但是没有可用的客户端证书Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_77");
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_87            } else {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52                out.println("这不是一个HTTPS请求,因此无法获得客户端证书列表Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_77 ");
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82            }
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82        }
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        out.close();
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82    }
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    public void doPost(HttpServletRequest request, HttpServletResponse response)
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_96            throws ServletException, IOException {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        doGet(request, response);
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82    }
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52    
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_100    /**
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52     * <p>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52     * 校验证书是否过期
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52     * </p>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52     * 
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52     * @param certificate
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52     * @return
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82     */
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_108    private boolean verifyCertificate(X509Certificate certificate) {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        boolean valid = true;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_110        try {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52            certificate.checkValidity();
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_112        } catch (Exception e) {
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52            e.printStackTrace();
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52            valid = false;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82        }
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52        return valid;
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_82    }
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_52
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_59}
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl

web.xml
说明:该演示项目强制使用了SSL,即普通的HTTP请求也会强制重定向为HTTPS请求,配置在最下面,可以去除,这样HTTP和HTTPS都可以访问。
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<?xml version="1.0" encoding="UTF-8"?>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<web-app version="3.0" 
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    xmlns="http://java.sun.com/xml/ns/javaee" 
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl      <display-name>Secure Sockets Layer</display-name>    
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    <servlet>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        <servlet-name>SSLServlet</servlet-name>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        <servlet-class>com.icesoft.servlet.SSLServlet</servlet-class>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    </servlet>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    <servlet-mapping>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        <servlet-name>SSLServlet</servlet-name>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        <url-pattern>/sslServlet</url-pattern>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    </servlet-mapping>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    <welcome-file-list>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl      <welcome-file>index.jsp</welcome-file>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    </welcome-file-list>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    <!-- 强制SSL配置,即普通的请求也会重定向为SSL请求 -->  
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    <security-constraint>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        <web-resource-collection>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl            <web-resource-name>SSL</web-resource-name>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl            <url-pattern>/*</url-pattern><!-- 全站使用SSL -->
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        </web-resource-collection>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        <user-data-constraint>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl            <description>SSL required</description>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl            <!-- CONFIDENTIAL: 要保证服务器和客户端之间传输的数据不能够被修改,且不能被第三方查看到 -->
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl            <!-- INTEGRAL: 要保证服务器和client之间传输的数据不能够被修改 -->
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl            <!-- NONE: 指示容器必须能够在任一的连接上提供数据。(即用HTTP或HTTPS,由客户端来决定)-->
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl            <transport-guarantee>CONFIDENTIAL</transport-guarantee>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl        </user-data-constraint>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    </security-constraint>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl</web-app>


index.jsp
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_157<%@ page language="java" pageEncoding="UTF-8"%>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<html>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<head>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<title>客户端证书上传</title>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<meta http-equiv="pragma" content="no-cache">
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<meta http-equiv="cache-control" content="no-cache">
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<meta http-equiv="expires" content="0">    
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl</head>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<body>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl<form action="${pageContext.request.contextPath}/sslServlet" method="post">
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl    <input type="submit"  value="提交证书"/>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl</form>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl</body>
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl</html>


四、演示及配置
发布演示项目,通过浏览器访问:http://127.0.0.1:8080/SSLhttps://127.0.0.1:8443/SSL,得到相同的结果,如图:

Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_173

Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_174


得到如上结果的原始是因为客户端没有通过服务端的安全认证,接下来将服务端给客户端颁发的证书导入到浏览器中:
双击“client.p12”
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_175


弹出窗口,下一步
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_176


默认,下一步
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_177


输入生成密钥时的密码“123456”,下一步
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_178


下一步
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_179


完成
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_180


成功
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_181


再次访问http://127.0.0.1:8080/SSLhttps://127.0.0.1:8443/SSL,弹出提示框:
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_182


点击确定后,IE浏览器自动阻止了继续访问,并给予警告提示,原因是浏览器中未导入该网站的可信证书
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_183

Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_184


点击“继续浏览此网站”,弹出提示,点击确定
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_185


哇!鲜红的地址栏,够醒目吧!你访问的网站不安全那,亲!
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_186


点击“提交证书”按钮,返回正确结果!
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_187


可以看出,客户端并没有服务端那么严格,只要未通过验证就甭想访问,下面将服务端生成的信任证书导入到浏览器的根证书中,这样红色的地址栏就会消失了!
开始导入服务端信任证书,不能双击“server.cer”,需要手动导入到受信任的根证书机构中去。
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_188


浏览器Internet选项-内容-证书
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_189


点击“受信任的根证书颁发机构”
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_190


点击“导入”
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_191


下一步
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_192


手动选择“server.cer”,下一步


Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_193



下一步
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_194


完成
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_195


点“是”

Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_196


成功
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_197




可以看到我们刚刚导入的根证书
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_198


把所有浏览器窗口都关掉,再次访问网站,发现鲜红色已经逝去
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_199


点击“提交证书”按钮,一切正常了,双向认证的DEMO结束了!
Java Tomcat SSL 服务端/客户端双向认证(一)_java ssl_200




全文完!

Feedback

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-08-18 17:54 by 爱学习的猪
你好!我是这篇文章的读者,我也是按照上面的方法配置好了tomcat,当我再次访问http://127.0.0.1:8080/SSL或https://127.0.0.1:8443/SSL,弹出提示框,点击确定后,不是进入的IE浏览器自动阻止了继续访问页面,而是进入了网页无法访问页面,这是怎么了呢?谢谢解答

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-09-07 10:04 by Jakey
请问第5步中生成的 client.truststore 这个文件有什么用?

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-09-07 18:13 by IceWee
@爱学习的猪 
你的浏览器没有导入证书,所以直接就被拒绝了,客户端不信任服务端,被浏览器自动阻止了

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-09-07 18:13 by IceWee
@Jakey 
让客户端信任服务端的证书

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-11-20 17:50 by redocde
看了N多的双向配置SSL的教程,都是抄袭来抄袭去的,还是楼主的可用,一次成功.thanks

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-11-20 17:57 by redocde
第五步是必须的吗?将服务端证书导入到信任库中,没看懂什么意思.

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-11-21 09:59 by IceWee
@redocde 
是的,并不是必须的,只是会有警示提示而已

# re: Java Tomcat SSL 服务端/客户端双向认证(一)  回复  更多评论   

2012-12-24 21:30 by Francis
你好,我照着你的这个做,成功了,表示感谢。
不过我有一些问题,你在最开始提到的服务器和客户端发来的证书做匹配,如果匹配不成功则不显示页面,这点没见你的demo里面有,请问这点您做到了吗?是在程序里面做还是修改服务器的一些配置?这点很好奇,如有结果希望您能答复一下

另外还有一个小问题,就是客户端的证书可以和IP绑定吗?如果安全措施周全点的话会希望客户端的证书只能是在指定IP上面使用,并不是所有客户端都可以用一个证书。
603005981@qq.com