1

我创建了两个类服务器和客户端。以 ssl 开头的服务器如下

HttpServer server =
  vertx.createHttpServer(new HttpServerOptions().setSsl(true).setKeyStoreOptions(
    new JksOptions().setPath("server-keystore.jks").setPassword("wibble")
  ));

还有一个即客户端

vertx.createHttpClient(new HttpClientOptions().setSsl(true)).getNow(4443, "localhost", "/", resp -> {
      System.out.println("Got response " + resp.statusCode());
      resp.bodyHandler(body -> System.out.println("Got data " + body.toString("ISO-8859-1")));
    });

在客户端上运行两者时,我收到“无法创建 SSL 连接”。有什么方法可以配置与 ssl 相关的任何内容吗?

4

1 回答 1

2

要在 vertx 中启用 ssl,您可以使用keystore.jks文件

然后使用以下配置:

HttpServerOptions secureOptions = new HttpServerOptions();
    if (Configuration.SSL_enabled) {
        LOG.debug("Secure Transport Protocol [ SSL/TLS ] has been enabled !!! ");
        secureOptions.setSsl(true)
                .setKeyStoreOptions(new JksOptions().setPath(Configuration.SSL_filename)
                        .setPassword(Configuration.SSL_password))
                .setTrustStoreOptions(new JksOptions().setPath(Configuration.SSL_filename)
                        .setPassword(Configuration.SSL_password))
                .addEnabledSecureTransportProtocol(Constants.TLS_VERSION_1)
                .addEnabledSecureTransportProtocol(Constants.TLS_VERSION_2);

    }

   vertx.createHttpServer(secureOptions).requestHandler(router::accept).listen(Configuration.port);

我希望这能帮到您 :)

于 2017-04-12T03:57:14.527 回答