Итак, я пытаюсь создать сервер API REST с помощью Grizzly/Jersey, и он работает нормально, но я не могу понять, как включить http2. Документация по этому вопросу почти не существует. Это то, что у меня есть:Встроенный Java-сервер с использованием Grizzly: как вы включаете 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 файл:
<dependency>
<groupId>org.glassfish.grizzly</groupId>
<artifactId>grizzly-http2</artifactId>
<version>2.3.24</version>
</dependency>
<dependency>
<groupId>org.glassfish.grizzly</groupId>
<artifactId>grizzly-npn-bootstrap</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.glassfish.grizzly</groupId>
<artifactId>grizzly-npn-api</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-grizzly2-http</artifactId>
</dependency>
Когда я протестировать сервер с завитком -v --http2 ..., я получаю
- ...
- ALPN/NPN, сервер не согласен с протоколом
- SSL гр onnection использованием TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256
- ...
ли кто-то знает, чего не хватает?