2014-10-28 66 views
0

有没有办法运行Spring Boot应用程序(runnable war),以便它监听两个端口 - 一个使用SSL,另一个使用SSL。我使用的是嵌入式的Tomcat 8.用SSL和未加密的方式运行Spring Boot应用程序(嵌入式Tomcat)

SSL目前正在使用

@Bean 
@Profile('tls') 
EmbeddedServletContainerCustomizer servletContainerCustomizer() 
throws Exception { 

    new EmbeddedServletContainerCustomizer() { 
     @Override 
     public void customize (ConfigurableEmbeddedServletContainer container) { 
      TomcatEmbeddedServletContainerFactory tomcat = (TomcatEmbeddedServletContainerFactory) container 
      tomcat.addConnectorCustomizers (
        new TomcatConnectorCustomizer() { 
         @Override 
         public void customize (Connector connector) { 
          connector.setPort  (Integer.parseInt (retrieveRequiredSpringProperty ('ssl.connection.port'))) 
          connector.setSecure (true) 
          connector.setScheme ('https') 
          connector.setProtocol (retrieveSpringPropertyOrSpecified ('ssl.connection.protocol', 'HTTP/1.1')) 

          Http11NioProtocol proto = (Http11NioProtocol) connector.getProtocolHandler() 
          proto.setSSLEnabled (true) 
          proto.setKeystoreFile (retrieveRequiredSpringProperty ('ssl.protocol.keystore.file')) 
          proto.setKeystorePass (retrieveRequiredSpringProperty ('ssl.protocol.keystore.password')) 
          proto.setKeyPass  (retrieveSpringPropertyOrSpecified ('ssl.protocol.keystore.cert.password', null)) 
          proto.setKeystoreType ('JKS') 
          proto.setKeyAlias  (retrieveRequiredSpringProperty ('ssl.protocol.keystore.cert.name')) 
          proto.setSslProtocol ('TLS') 
          proto.setClientAuth ('false') 
         } 
        } 
      ) 
     } 
    } 
} 

我已经使用多个TomcatConnectorCustomizer试过了,但列出的最后一个似乎覆盖,而不是要加配置。

任何建议都欢迎一如既往!

回答

2

A TomcatConnectorCustomizer只修改现有的Connector(线索名称)。要添加额外的连接器,您只需要一个不同的API(例如here),例如(从样品复制):

@Bean 
public EmbeddedServletContainerFactory servletContainer() { 
    TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory(); 
    tomcat.addAdditionalTomcatConnectors(createConnector()); 
    return tomcat; 
} 
相关问题