java 限制https_优雅处理HTTPS中的证书问题

本文介绍了Java中处理HTTPS证书问题的方法,包括访问自签名HTTPS网站、处理高版本JRE与SSLv3/SSLv2站点的兼容性,以及如何在不信任所有证书的情况下进行优雅操作。通过下载并加载服务端证书,自定义SSLContext,以及调整JRE的SSL协议和算法配置,可以实现安全且优雅的HTTPS连接。
摘要由CSDN通过智能技术生成

Java中HTTPS会遇到的问题

访问自签名的HTTPS网站

高版本JRE访问SSLv3/SSLv2站点

一些银行接口需要加载keystore的场景

* 如果要了解SSL历史也可以看看这篇文章。

1 访问自签名的HTTPS网站

常常看到的回答是直接通过信任所有来支持, 这不优雅; 优雅的操作应该:

下载服务端的CA证书

# 方式1: 导出DER格式的证书

# 这里需要通过指定servername来保证导出的证书和当前域名匹配

openssl s_client -showcerts -connect self-signed.badssl.com:443 -servername self-signed.badssl.com /dev/null|openssl x509 -outform der >self-signed.badssl.com.der

代码中通过加载服务端证书后通过自定义SSLContext访问目标服务器:

private SSLContext sslContext(File certificateFile, String certificateType) {

InputStream inputStream = null;

try {

inputStream = new FileInputStream(certificateFile);

CertificateFactory cf = CertificateFactory.getInstance(certificateType);

Certificate certificate = cf.generateCertificate(inputStream);

System.out.println("ca=" + ((X509Certificate) certificate).getSubjectDN());

String alias = ((X509Certificate) certificate).getSubjectDN().toString();

KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());

keyStore.load(null, null);

keyStore.setCertificateEntry(alias, certificate);

// Create a KeyStore containing our trusted CAs

SSLContext sslcontext = SSLContexts.custom()

.loadTrustMaterial(keyStore, new TrustSelfSignedStrategy())

.build();

return sslcontext;

} catch (IOException e) {

throw new RuntimeException(e);

} catch (CertificateException e) {

throw new RuntimeException(e);

} catch (NoSuchAlgorithmException e) {

throw new RuntimeException(e);

} catch (KeyStoreException e) {

throw new RuntimeException(e);

} catch (KeyManagementException e) {

throw new RuntimeException(e);

} finally {

if (inputStream != null) try { inputStream.close(); } catch (IOException e) { }

}

}

@Test

public void testSelfSign() throws IOException {

File certFile = ResourceUtils.getFile(this.getClass().getResource("/root.cer"));

CloseableHttpClient httpclient = HttpClients.custom()

.setSSLContext(sslContext(certFile, "X.5

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值