MockServer 如何实现 JUnit 双向 TLS 身份验证?

发布时间:2021-03-05 16:10

我的 SpringBoot 应用程序正在使用第三个库/框架连接到第三方服务器。 这些远程服务器之一(尚不可用)将需要相互 TLS (https) 连接。我的代码将为框架提供 P12 和密码,以便连接到该远程服务器。我需要用 Junit 集成测试来测试这部分。

MockServer(来自 www.mock-server.com)已用于我们的 Junit IT,但尚未用于双向 TLS 身份验证,作为新手,我对如何实现这一点感到困惑。 形成文档 (https://www.mock-server.com/mock_server/HTTPS_TLS.html) 我在我的 Junit 测试中添加了以下配置:

@BeforeAll
public static void initServer(){

  //ensure https will use SSL context defined by MockServer to allow
  // dynamically generated certificates to be accepted
  HttpsURLConnection.setDefaultSSLSocketFactory(new KeyStoreFactory(new 
  MockServerLogger()).sslContext().getSocketFactory());

  File certif = ResourceUtils.getFile("classpath:mtls/test-cert.crt");
  ConfigurationProperties.tlsMutualAuthenticationCertificateChain(certif.getPath());
  ConfigurationProperties.tlsMutualAuthenticationRequired(true);

  mockServer = ClientAndServer.startClientAndServer(80,443);

  etc…
}

但没有任何效果,我在测试中遗漏了一些代码
在日志中我可以看到,即:

"MockServerEventLog - no tls for connection"

我找不到有关此用例的任何清晰简单的教程。任何帮助都会很棒。

那么如何使用具有双向 TLS 身份验证的 Mockserver 来实现完整的 Junit 集成测试?

回答1