Spring 启动 : Enable HTTPS for embedded tomcat

标签 spring tomcat ssl spring-boot

使用以下命令创建 keystore :
keytool -genkey -alias tomcat -storetype PKCS12 -keyalg RSA -keysize 2048 -keystore keystore.p12 -validity 3650

在 application.properties 文件中添加了以下设置:

server.ssl.key-store=keystore.p12
server.ssl.key-store-password=######
server.ssl.keyStoreType=PKCS12
server.ssl.keyAlias=tomcat
#server port config
server.port=8080
server.http.port=8081

编写如下代码:

public EmbeddedServletContainerFactory servletContainer() {
        TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory() {
            @Override
            protected void postProcessContext(Context context) {
                SecurityConstraint securityConstraint = new SecurityConstraint();
                securityConstraint.setUserConstraint("CONFIDENTIAL");
                SecurityCollection collection = new SecurityCollection();
                collection.addPattern("/*");
                securityConstraint.addCollection(collection);
                context.addConstraint(securityConstraint);
            }
        };

        tomcat.addAdditionalTomcatConnectors(initiateHttpConnector());
        return tomcat;
    }

应用程序启动正常,没有任何错误。我可以在日志中看到以下消息: s.b.c.e.t.TomcatEmbeddedServletContainer:Tomcat 在端口上启动:8080 (https) 8081 (http)

但是当我发送请求 https://localhost:8081/hello 时,响应从服务器发回并且服务器日志上没有任何事件。不确定发生了什么。

最佳答案

嵌入式 Tomcat 的启动消息清楚地表明您的 ssl/tls 连接正在您使用 server.port 指定的端口上运行:

Tomcat started on port(s): 8080 (https)

所以你只是有一个错误的端口/协议(protocol)组合。 https://localhost:8080应该可以。

但通常您的浏览器会提示并显示一条消息说明这一点。出于好奇,您可以查看调用 https://www.google.com:80 时浏览器中发生的情况。

关于 Spring 启动 : Enable HTTPS for embedded tomcat,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36490709/

相关文章:

java - Spring 重载构造函数 Autowiring

java - Eclipse WTP 和 Tomcat 中的 clean 和 clean 工作目录的区别

java - SSL 握手时缺少 ServerHelloDone

java - 如何让线程等待,直到另一个线程完成该方法执行

mysql - MariaDB 字符编码

java - tomcat的pkcs12证书是否需要加ca证书

java - Apache Tomcat 是否阻止了客户端 IP 地址?

Node.js Nginx LetsEncrypt 坏网关

供内部使用的 SSL 签名证书

java - 努力在 Spring 创造 bean