springboot项目因为需要测试接口,模拟生产环境用https服务启动,但是这个过程遇到不少问题。
首先我们需要有一个keystore的加密文件,由于是只是模拟生产环境而已,所以就用jdk自带的keytools生成
keytool -genkey -alias tomcat -keyalg RSA -keystore ./server.keystore
这个命令就可以生成一个用于https服务用到的证书文件
然后把证书文件放在项目的resource目录下
按照其它博客的说法是只需要在application.properties中配置相关配置启动以后就可以通过https访问了
server.port=8080
server.ssl.key-store=classpath:server.keystore
server.ssl.key-alias=tomcat
server.ssl.enabled=true
server.ssl.key-store-password=654321
server.ssl.key-store-type=JKS
但是就是这一步启动经常出现各种错误信息,其中困扰了我很久的就是
java.io.IOException: Invalid keystore format
这个错误我查了一下网上的解释可能是由于项目在打包的时候对resource下的文件做了压缩处理,导致证书文件改变了。需要在pom.xml中对这个文件进行过滤
<resource>
<directory>src/main/resources</directory>
<includes>
<include>*.*</include>
<include>**/*</include>
</includes>
<excludes>
<exclude>*.keystore</exclude>
</excludes>
<!-- must,for springboot profile -->
<filtering>true</filtering>
</resource>
这样配置以后之前的异常确实没有了,但是启动后会抛出改文件找不到的异常,然后我去编译后的文件夹下面看确实是被过滤掉了,但是这时候肯定不能通过maven再去打包了,于是我直接把keystore文件复制到编译后的文件夹中,再启动,问题果然解决了
甘肃华科信息技术有限责任公司 版权所有 陇ICP备17001897号-1 甘公网安备 62010202001329 号