所以我试图使用Grizzly / Jersey创建一个REST API服务器,它工作正常,但我无法弄清楚如何启用http2。关于这个问题的文件几乎都不存在。这是我拥有的:
private static SSLContext getSSLContext(final String keystore) throws Exception {
SSLContext sslContext = SSLContext.getInstance("TLSv1");
final char[] passphrase = "changeit".toCharArray();
final KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
final KeyStore ks = KeyStore.getInstance("JKS");
try (InputStream stream = Main.class.getResourceAsStream(keystore)) {
ks.load(stream, passphrase);
}
kmf.init(ks, passphrase);
sslContext.init(kmf.getKeyManagers(), null, null);
return sslContext;
}
final ResourceConfig rc = new ResourceConfig().packages("path.to.package");
final HttpServer server = GrizzlyHttpServerFactory.createHttpServer(uri, rc, false);
final NetworkListener listener = server.getListeners().iterator().next();
listener.registerAddOn(new Http2AddOn());
listener.setSecure(true);
final SSLEngineConfigurator configurator =
new SSLEngineConfigurator(
getSSLContext("keystore.jks"),
false,
false,
false
);
listener.setSSLEngineConfig(configurator);而且,据我所知,我在我的pom.xml文件中拥有所有适当的依赖关系:
org.glassfish.grizzly
grizzly-http2
2.3.24
org.glassfish.grizzly
grizzly-npn-bootstrap
1.2
org.glassfish.grizzly
grizzly-npn-api
1.2
org.glassfish.jersey.containers
jersey-container-grizzly2-http
当我用curl -v --http2 ...测试服务器时,我得到了
...
ALPN / NPN,服务器不同意协议
使用TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256的SSL连接
...
有人知道缺少什么吗?