java web https 单向认证 双向认证

本文介绍了在Java Web项目中如何设置HTTPS,包括创建keystore文件、配置Tomcat服务器和Web应用,以及实现客户端的HTTP请求。讲解了单向和双向认证的步骤,提供了代码示例。
摘要由CSDN通过智能技术生成

        研究了有一天了,最后一博讲解https,https接口也是以后接口开发中必定会碰到的,这里只是简单介绍一下简单的java工程中的实现,在更复杂的项目中必定有更优秀的框架来实现。

        第一步先创建两个秘钥库,服务的库和客户端库,我这里都用keystore文件保存。

        jdk自带的keytool命令生成各自的秘钥库

keytoo -keygen -alias server -keypass 123456 -keysize 1024 -keyalg RSA -validity 720 -keystore "e:/keystore/server.keystore"  -storeypass 123456 -dname "CN=localhost,OU=sf,O=cib,L=sz,ST=gd,C=cn"

keytoo -keygen -alias client -keypass 123456 -keysize 1024 -keyalg RSA -validity 720 -keystore "e:/keystore/client.keystore"  -storeypass 123456 -dname "CN=localhost,OU=sf,O=cib,L=sz,ST=gd,C=cn"

      导出各自秘钥并导入到对方的秘钥库中

keytool -export -alias server -keystore "e:/keystore/server.keystore" -file "e:/keystore/cer/server.cer"  -storeypass 123456

keytool -export -alias client-keystore "e:/keystore/client.keystore" -file "e:/keystore/cer/client.cer"  -storeypass 123456

keytool -import -alias client -file "e:/keystore/cer/client.cer"  -keystore "e:/keystore/server.keystore" -storeypass 123456

keytool -import -alias server -file "e:/keystore/cer/server .cer"  -keystore "e:/keystore/client.keystore" -storeypass 123456

      查看秘钥库内容

keytool -list -v -keystore -keystore "e:/keystore/server.keystore"  -storepass 123456

配置tomcat server.xml服务器SSL请求 clientAuth="true" 为双向认证

   <Connector SSLEnabled="true" 
    keystoreFile="E:\keystore\httpsweb.keystore" 
    keystorePass="changeit" 
    truststoreFile="E:\keystore\httpsweb.keystore" 
    truststorePass="changeit" scheme="https" secure="true"
    clientAuth="true" sslProtocol="SSL"
    maxThreads="150" port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"/>

配置web.xml

  <servlet>
    <servlet-name>httpsweb</servlet-name>
    <servlet-class>com.wm.core.HttpswebServlet</servlet-class>
  </servlet>
  <servlet-mapping>
        <servlet-name>httpsweb</servlet-name>
        <url-pattern>/ssl</url-pattern>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值