栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

java-忽略过期的SSL证书

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java-忽略过期的SSL证书

您应该构建一个

TrustManager
包装默认信任管理器的,捕获
CertificiateExpiredException
并忽略它。

注意:如此答案中所述,此设置是否安全在很大程度上取决于实现。特别是,它依赖于在正确检查所有其他内容之后最后执行的日期验证。

遵循这些原则的东西应该起作用:

TrustManagerFactory tmf = TrustManagerFactory.getInstance(    TrustManagerFactory.getDefaultAlgorithm());// Initialise the TMF as you normally would, for example:tmf.init((KeyStore)null);TrustManager[] trustManagers = tmf.getTrustManagers();final X509TrustManager origTrustmanager = (X509TrustManager)trustManagers[0];TrustManager[] wrappedTrustManagers = new TrustManager[]{   new X509TrustManager() {       public java.security.cert.X509Certificate[] getAcceptedIssuers() {          return origTrustmanager.getAcceptedIssuers();       }       public void checkClientTrusted(X509Certificate[] certs, String authType) {origTrustmanager.checkClientTrusted(certs, authType);       }       public void checkServerTrusted(X509Certificate[] certs, String authType) {try {    origTrustmanager.checkServerTrusted(certs, authType);} catch (CertificateExpiredException e) {}       }   }};SSLContext sc = SSLContext.getInstance("TLS");sc.init(null, wrappedTrustManagers, null);HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

CertificateException
当证书有问题时,信任管理器将抛出s(有关详细信息,请参见子类)。具体说明您要捕获/忽略的内容。您真正想要验证的所有内容都必须在可能捕获到的东西被抛出之前进行检查,否则您也必须手动进行验证。比这更轻松的事情(特别是不做任何事情,因此不会引发任何异常)将完全忽略证书验证和确认,这与使用匿名密码套件或忽略身份验证大致相同。这将破坏使用SSL
/ TLS的安全性目的(而不是在到期日时更加灵活)。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/485845.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号