![](/img/trans.png)
[英]How to load trust store from linux file system (not from classpath) in Spring Boot application
[英]How to load a trust store file to below code in Spring Java
我正在与服务器进行通信的工作代码,但是现在将信任存储文件添加到服务器以进行身份验证。 如何将trust store.jks
文件添加到以下代码:
我的Java代码:
KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
keyStore.load(new FileInputStream("/users/Documents/workspace/publickey.cert"),
"password".toCharArray());
SSLConnectionSocketFactory socketFactory = new SSLConnectionSocketFactory(
new SSLContextBuilder()
.loadTrustMaterial(null, new TrustSelfSignedStrategy())
.loadKeyMaterial(keyStore, "changeit".toCharArray()).build());
HttpClient httpClient = HttpClients.custom().setSSLSocketFactory(socketFactory).build();
ClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory(
httpClient);
RestTemplate restTemplate = new RestTemplate(requestFactory);
ResponseEntity<String> result = restTemplate.exchange("url", HttpMethod.GET, new HttpEntity<String>(), String.class);
假设您将.cert
文件正确导入到store.jks
文件中,则可以执行类似的操作来加载store.jks
文件(或继续使用当前使用的方法来加载文件)。
KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
InputStream instream = classLoader.getResourceAsStream("store.jks");
keyStore.load(instream, "JKSpassword".toCharArray());
instream.close();
从那里开始,除了为SSLContextBuilder
loadTrustMaterial
之外,其他都loadTrustMaterial
SSLConnectionSocketFactory socketFactory = new SSLConnectionSocketFactory(
new SSLContextBuilder()
.loadTrustMaterial(keyStore, new TrustSelfSignedStrategy()).build());
希望这可以帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.