0

在我的项目使用 1.4.0.M3 版本的 Spring Boot 前几周,它使用了 tomcat-embedded-core-8.0.33。在这里,我能够使用以下代码创建多连接器:

@Bean
EmbeddedServletContainerFactory servletContainer() {
    TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();
    tomcat.addAdditionalTomcatConnectors(createStandardConnector());
    return tomcat;
}

private Connector createStandardConnector() {
    Connector connector = new Connector(Http11Nio2Protocol.class.getCanonicalName());
    connector.setPort(expiredCertPort);
    connector.setScheme("https");
    connector.setSecure(true);
    Http11Nio2Protocol protocolHandler = (Http11Nio2Protocol) connector.getProtocolHandler();

    protocolHandler.setSSLEnabled(true);
    protocolHandler.getEndpoint().setTrustManagerClassName(TimelessTrustManager.class.getCanonicalName());
    return connector;
}

问题是从 1.4.0.RELEASE 版本开始,Spring Boot 使用 8.5.* Tomcat,其中 .getEndpoint() 方法被声明为受保护。

如何以编程方式为特定连接器或协议处理程序安装 TrustManager?

4

1 回答 1

0

.setTrustManagerClassName(字符串)

于 2016-08-26T18:49:27.107 回答