Tomcat 将 Windows 证书存储用于 SSL

标签 tomcat ssl

我使用 Tomcat 9.0.10 并希望使用 Windows 证书存储来保存 SSL 私钥和证书。有another thread here ,这似乎有答案,但是在启动Tomcat时出现异常。

我的 server.xml 看起来像这样:

<Connector port="443"
       protocol="org.apache.coyote.http11.Http11NioProtocol"
       SSLEnabled="true"
       maxthreads="150"
       scheme="https"
       secure="true"
       keyAlias="SERVER-TST-1.domain.local"
       keystoreFile=""
       keystoreType="Windows-ROOT"
       clientAuth="false"
       sslProtocol="TLS"
       connectionTimeout="20000"
       keepAliveTimeout="200000" />

这是一个异常(exception):
 org.apache.catalina.util.LifecycleBase.handleSubClassException Failed to initialize component [Connector[HTTP/1.1-443]]
 org.apache.catalina.LifecycleException: Protocol handler initialization failed
    at org.apache.catalina.connector.Connector.initInternal(Connector.java:935)
    at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:136)
    at org.apache.catalina.core.StandardService.initInternal(StandardService.java:530)
    at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:136)
    at org.apache.catalina.core.StandardServer.initInternal(StandardServer.java:852)
    at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:136)
    at org.apache.catalina.startup.Catalina.load(Catalina.java:633)
    at org.apache.catalina.startup.Catalina.load(Catalina.java:656)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.apache.catalina.startup.Bootstrap.load(Bootstrap.java:306)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:491)
Caused by: java.lang.IllegalArgumentException: Alias name [SERVER-TST-1.domain.local] does not identify a key entry
    at org.apache.tomcat.util.net.AbstractJsseEndpoint.createSSLContext(AbstractJsseEndpoint.java:114)
    at org.apache.tomcat.util.net.AbstractJsseEndpoint.initialiseSsl(AbstractJsseEndpoint.java:85)
    at org.apache.tomcat.util.net.NioEndpoint.bind(NioEndpoint.java:216)
    at org.apache.tomcat.util.net.AbstractEndpoint.init(AbstractEndpoint.java:1043)
    at org.apache.coyote.AbstractProtocol.init(AbstractProtocol.java:540)
    at org.apache.coyote.http11.AbstractHttp11Protocol.init(AbstractHttp11Protocol.java:74)
    at org.apache.catalina.connector.Connector.initInternal(Connector.java:932)
    ... 13 more
Caused by: java.io.IOException: Alias name [SERVER-TST-1.domain.local] does not identify a key entry
    at org.apache.tomcat.util.net.jsse.JSSEUtil.getKeyManagers(JSSEUtil.java:229)
    at org.apache.tomcat.util.net.openssl.OpenSSLUtil.getKeyManagers(OpenSSLUtil.java:79)
    at org.apache.tomcat.util.net.AbstractJsseEndpoint.createSSLContext(AbstractJsseEndpoint.java:112)
    ... 19 more

该证书在 Windows 证书存储中也有私钥。我也将它们导入到本地计算机和当前用户存储中。
SSL 证书和整个链都在证书存储中。此外,证书中的 CN 是 SERVER-TST-1.domain.local
如果我将 Tomcat 配置为使用导入证书+私钥和链的 PFX 文件,那么一切正常。我只是想避免使用明文形式的 keystore 密码,因此我想使用 Windows 证书存储。

最佳答案

根据Leveraging Security in the Native Platform Using Java
Windows-ROOT keystore 包含机器信任的所有根 CA 证书。
您应该将 keystoreType 设置为 Windows-MY 其中包含用户的私钥和相关的证书链。
此外,还有一个开放的 OpenJDK bug无法读取本地计算机证书。

关于Tomcat 将 Windows 证书存储用于 SSL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51603375/

相关文章:

Maven Tomcat(嵌入式)

ssl - Erlang SSL - 证书不适合 sni_fun 回调

ssl - 如何将 .p12 文件更改为 .key 文件

tomcat - 使用 CXF 将 POJO 公开为 Web 服务,而无需部署为 WAR 文件

java - tomcat中Struts2启动时出现404错误

java - Spring security OAuth2 中的 JSON 请求不工作 tomcat 9

java - 常量池中的无效字节标记 : 19 error message

ios - AFNetworking 2.0 + TLS 1.2

.htaccess - Codeigniter 删除 https 上的 index.php

ssl - 如何在 Glassfish 3.1.2.2 上设置 ssl