当前位置: 首页 > news >正文

在tomcat7中启用HTTPS的详细配置

详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt385

最简单的方法,直接用java里的keytool工具生成一个keystore文件,然后直接用这个文件启用https就可以了。

方法如下:

命令行执行%JAVA_HOME%\bin\keytool -genkey -alias tomcat -keyalg RSA

执行过程中会询问你一些信息,比如国家代码,省市等,其中需要填写两个密码,一次在开头,一次在最后,请保持两个密码相同。比如,我将密码都设成s3cret。

如果不同,启动会报错,大概是下面这样的

java.io.IOException: Cannot recover key

执行完成后会生成一个.keystore文件,将它复制到tomcat的bin目录下(并不一定,放哪里都可以)

打开conf目录下的server.xml文件,找到以下这一段

它被注释掉了,将注释去掉,并将这一段改成以下

   

               maxThreads="150" scheme="https" secure="true"

       keystoreFile="bin/.keystore" keystorePass=" s3cret"

               clientAuth="false" sslProtocol="TLS" />

之后启动tomcat就可以了,通过https方式访问8443端口,就能看到效果。如果用http访问之前的端口,那么还是普通的未加密连接。

到这里问题来了,我的目的是启用https,但现在http还能访问,那么就可以绕开https。https也就起不了什么作用了。因此要强制访问https。

打开你的web应用的web.xml文件,在最后加上这样一段

Protected Context

/*

CONFIDENTIAL

重启tomcat,现在你放问原来的地址,假设是http://localhost:8080/mywebapp/,可以看到,连接被重定向到了https的连接

https://localhost:8443/mywebapp/。这样,我们的目的达到了。

但似乎还有点小问题,keystorePass="s3cret",这个密码直接被明码方式卸载server.xml里。总觉得有还是有点不爽。

 

那么还有一种稍微复杂点的方式,我们使用openssl。

 

首先,需要下载openssl,为了方便,可以下载一个绿色版,http://www.itrus.com.cn/verisignchina/Service/soft/autocsr.rar

加压后除了openssl.exe以外,还有一个bat文件,这个可以帮助我们快速创建证书申请文件。

运行autocsr.bat,按照提示输入信息,之后按任意键确认。你会得到两个文件,一个server.key,这是私钥文件,还有一个名为certreq.csr的证书请求文件。

如果你要向证书颁发机构申请正式的安全证书,那么就把这个certreq.csr文件发给他们就行了。他们会给你发来两个cer文件,一个是服务器证书,一个是根证书

如果你只是要使用https,那么证书自己签署就可以了。

在命令行下进入刚才解压的目录,找到openssl.exe所在的目录,执行以下命令

openssl x509 -req -in certreq.csr -out cert.cer -signkey server.key -days 3650

现在你将得到一个名为cert.cer的证书文件。

修改server.xml将

   

               maxThreads="150" scheme="https" secure="true"

       keystoreFile="bin/.keystore" keystorePass=" s3cret"

               clientAuth="false" sslProtocol="TLS" />

修改为以下内容(假设cert.cer和server.key文件都放在tomcat的conf目录下)

               maxThreads="150" scheme="https" secure="true"

       SSLCertificateFile="conf/cert.cer"

       SSLCertificateKeyFile="conf/server.key"

               sslProtocol="TLS" />

 

PS.如果真的向证书颁发机构申请到了正式的安全证书,那么配置还有点不同,如下

               maxThreads="150" scheme="https" secure="true"

  SSLCertificateFile="conf/server.cer"

  SSLCertificateKeyFile="conf/server.key"

  SSLCertificateChainFile="conf/intermediate.cer"

               sslProtocol="TLS" />

因为证书颁发机构会给两个整数,一个是签署后的服务器证书,还有一个中级CA证书,所以要多一行配置。
可能证书颁发机构只会给你服务器证书也就是server.cer,  中级的CA证书即 intermediate.cer 需要到
证书颁发机构提供的网站中去下载,具体的操作会为证书颁发机构给发的邮箱中会有相关的提示

好了,到这里都配置完了,重启tomcat,就可以看到效果。不过,看到的通常会是一个exception,大概是说APR not available

如果遇到这个异常,说明你的tomcat没有安装apr支持
apr安装详见:http://www.blogjava.net/yongboy/archive/2009/08/31/293343.html

之后启动tomcat,问题应该解决了,看起来效果和第一种方式没什么不同。

 

相关文章:

  • Neutron VxLAN + Linux Bridge 环境中的网络 MTU
  • 《C#本质论》读书笔记(16)构建自定义集合
  • Android真机抓屏- Android Screen Monitor
  • 20161122
  • 稳定,实际是暴风雨来临前的死寂
  • 单词接龙
  • Debug看方法的调用流程
  • WFS-GetFeature的请求方式和ajax提交方法
  • 杂七杂八(1)——如何查看本机的.NET Framework版本
  • 根据当月数据库自动生成下个月数据库--3
  • Bootstrap3 排版-对齐
  • 用python操作mysql数据库(之简单“插入数据”操作)
  • 数学之高幂次取模
  • iOS 地图缩放级别问题
  • docker学习实践之路[第四站]利用pm2镜像部署node应用
  • 【Redis学习笔记】2018-06-28 redis命令源码学习1
  • Angular js 常用指令ng-if、ng-class、ng-option、ng-value、ng-click是如何使用的?
  • django开发-定时任务的使用
  • Github访问慢解决办法
  • java小心机(3)| 浅析finalize()
  • Java知识点总结(JavaIO-打印流)
  • js正则,这点儿就够用了
  • leetcode讲解--894. All Possible Full Binary Trees
  • Promise初体验
  • Vue 动态创建 component
  • Vue实战(四)登录/注册页的实现
  • vue中实现单选
  • webpack+react项目初体验——记录我的webpack环境配置
  • 机器人定位导航技术 激光SLAM与视觉SLAM谁更胜一筹?
  • 小程序滚动组件,左边导航栏与右边内容联动效果实现
  • 一个JAVA程序员成长之路分享
  • Redis4.x新特性 -- 萌萌的MEMORY DOCTOR
  • ​Python 3 新特性:类型注解
  • #Linux(Source Insight安装及工程建立)
  • (搬运以学习)flask 上下文的实现
  • (六)Hibernate的二级缓存
  • (区间dp) (经典例题) 石子合并
  • (原创)攻击方式学习之(4) - 拒绝服务(DOS/DDOS/DRDOS)
  • (转)人的集合论——移山之道
  • (转)自己动手搭建Nginx+memcache+xdebug+php运行环境绿色版 For windows版
  • ***微信公众号支付+微信H5支付+微信扫码支付+小程序支付+APP微信支付解决方案总结...
  • .net core webapi Startup 注入ConfigurePrimaryHttpMessageHandler
  • .net refrector
  • .NET/C# 中你可以在代码中写多个 Main 函数,然后按需要随时切换
  • @ModelAttribute注解使用
  • @synthesize和@dynamic分别有什么作用?
  • [.net] 如何在mail的加入正文显示图片
  • [BZOJ4566][HAOI2016]找相同字符(SAM)
  • [C#]winform部署yolov9的onnx模型
  • [CSS3备忘] transform animation 等
  • [dart学习]第四篇:函数
  • [Firefly-Linux] RK3568 pca9555芯片驱动详解
  • [Head First设计模式]策略模式
  • [JMS 3] ActiveMQ实现简单的helloworld
  • [Latex学习笔记]数学公式基本命令