在 Spring 中启用 SSL 使用嵌入式 Tomcat 7 - FileNotFoundException 和 o.a.coyote.http11.Http11NioProtocol 问题

Enabling SSL in Spring Boot with an embedded Tomcat 7 - FileNotFoundException and o.a.coyote.http11.Http11NioProtocol issue

我正在尝试为我的 Spring 启动应用程序启用 SSL 以进行测试。我用这个命令行生成了一个密钥库文件:

keytool -genkey -alias tomcat
-storetype PKCS12 -keyalg RSA -keysize 2048
-keystore keystore.p12 -validity 3650

并将以下配置添加到我的 application.properties 文件中:

server.port=8443
server.ssl.key-store: keystore.p12
server.ssl.key-store-password: mypassword
server.ssl.keyStoreType: PKCS12
server.ssl.keyAlias: tomcat

当我 运行 带有嵌入式 Tomcat 8 版本的应用程序时,SSL 在构建过程中成功启用且没有错误。

但是当我 运行 它与嵌入式 Tomcat 7 版本通过改变 pom.xml 文件如下:

<properties>
    <tomcat.version>7.0.65</tomcat.version>
</properties>

SSL 未启用,我遇到了这些错误:

java.io.FileNotFoundException: /tmp/tomcat.4863947968145457153.8443/file:/home/yahyaharif/spring-workspace/demossl/keystore.p12 (No such file or directory)

org.apache.catalina.LifecycleException: Failed to start component [Connector[org.apache.coyote.http11.Http11NioProtocol-8443]]

org.springframework.boot.context.embedded.EmbeddedServletContainerExcepti> on: Unable to start embedded Tomcat servlet container

我查看了错误,发现我需要将一个嵌入式 servlet 容器 bean 添加到我的 main,但无济于事。

我还确保了密钥库文件的文件路径是正确的。

关于为什么 SSL 在嵌入式 Tomcat 8 而不是嵌入式 Tomcat 7 上完美启用的任何线索?

在 Tomcat8 中进行了更改,以允许从嵌入式 jar 文件中加载密钥库。它已经 backported to Tomcat 7 但在 7.0.66 发布之前不会可用

如果您尝试使用期望此更改存在的 Spring 引导版本(1.2.7 或更高版本),如果不存在,它将失败。在 Tomcat 7.0.66 发布之前,我认为您有两个选择:

  • 使用Tomcat8
  • 将 Tomcat 7 与 Spring Boot 1.2.6 或更早版本一起使用