java - 使用 http2 的 Jetty ssl 工厂不起作用

标签 java spring-boot ssl jetty jetty-9

我有一个使用 jetty 的简单 Spring 启动项目。
我在端口 443 上运行并使用 http1.1 就好了

@Bean(name = "containerCustomizer")
public WebServerFactoryCustomizer containerCustomizer()
{
    return (container -> ((JettyServletWebServerFactory) container).addServerCustomizers(server -> {
        // HTTPS
        SslContextFactory.Server sslContextFactory = new SslContextFactory.Server();
        sslContextFactory.setKeyStoreResource(Resource.newResource(
                getClass().getClassLoader().getResource("keystore.jks")));
        sslContextFactory.setKeyStorePassword("password");
        sslContextFactory.setProtocol("TLS");
        sslContextFactory.setKeyStoreType("JKS");

        HttpConfiguration https = new HttpConfiguration();
        https.addCustomizer(new SecureRequestCustomizer());
        SslConnectionFactory sslFactory = new SslConnectionFactory(sslContextFactory,
                                                                   HttpVersion.HTTP_1_1.asString());
        ServerConnector sslConnector = new ServerConnector(server, sslFactory, new HttpConnectionFactory(https));
        sslConnector.setPort(443);
        server.setConnectors(new Connector[] {sslConnector});
    }));
}
但是,一旦我通过替换 HttpVersion.HTTP_1_1.asString() 更改为 HTTP2与 HttpVersion.HTTP_2.asString()然后我得到异常
Caused by: java.lang.IllegalStateException: No protocol factory for SSL next protocol: 'HTTP/2.0' in ServerConnector@61e45f87{SSL, (ssl, http/1.1)}{0.0.0.0:443}
    at org.eclipse.jetty.server.AbstractConnector.doStart(AbstractConnector.java:317) ~[jetty-server-9.4.35.v20201120.jar:9.4.35.v20201120]
    at org.eclipse.jetty.server.AbstractNetworkConnector.doStart(AbstractNetworkConnector.java:81) ~[jetty-server-9.4.35.v20201120.jar:9.4.35.v20201120]
    at org.eclipse.jetty.server.ServerConnector.doStart(ServerConnector.java:234) ~[jetty-server-9.4.35.v20201120.jar:9.4.35.v20201120]
    at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:73) ~[jetty-util-9.4.35.v20201120.jar:9.4.35.v20201120]
    at org.springframework.boot.web.embedded.jetty.JettyWebServer.start(JettyWebServer.java:174) ~[spring-boot-2.3.7.RELEASE.jar:2.3.7.RELEASE]
    ... 16 common frames omitted

最佳答案

仅更改版本字符串是不够的。
你还需要...

  • ALPNServerConnectionFactory - 用于处理选择 HTTP/2 协议(protocol)的 TLS 层(称为 ALPN)
  • HTTP2ServerConnectionFactory - 用于使用 HTTP/2 协议(protocol)

  • embedded / Http2Server.java example 中所示
    关键是您将连接类型链接在一起,ALPN 到 HTTP2 到 HTTPS。
    // SSL Context Factory for HTTPS and HTTP/2
    SslContextFactory sslContextFactory = new SslContextFactory.Server();
    // configure sslContextFactory
    
    // HTTPS Configuration
    HttpConfiguration httpsConfig = new HttpConfiguration(httpConfig);
    httpsConfig.addCustomizer(new SecureRequestCustomizer());
    
    // HTTP/2 Connection Factory
    HTTP2ServerConnectionFactory h2 = new HTTP2ServerConnectionFactory(httpsConfig);
    
    ALPNServerConnectionFactory alpn = new ALPNServerConnectionFactory();
    alpn.setDefaultProtocol(http.getDefaultProtocol());
    
    // SSL Connection Factory
    SslConnectionFactory ssl = new SslConnectionFactory(sslContextFactory, alpn.getProtocol());
    
    // HTTP/2 Connector
    ServerConnector http2Connector =
        new ServerConnector(server, ssl, alpn, h2, new HttpConnectionFactory(httpsConfig));
    http2Connector.setPort(securePort);
    server.addConnector(http2Connector);
    

    关于java - 使用 http2 的 Jetty ssl 工厂不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65674450/

    相关文章:

    java - 非静态方法

    java - Spring Boot 和 Spring Data Rest

    java - Spring boot jpa通过实体管理器访问辅助数据源

    php - 在 wordpress 站点中安装 ssl 后,Authorize.net 无法正常工作

    java - 编译jsp WebLogic 12c时抛出错误

    java - 多层继承 - Java

    java - 如何为 Neo4j 的 RestGraphDatabase 关闭 SSL 验证?

    javascript - 来自 Firefox 扩展的基于 SSL 的 XMLHttpRequest

    java - 一次性将多个 Java Web 应用程序部署到 Glassfish

    java - spring jpa onetomany关系@Query不起作用