Android Nougat(7.0) 及以上出现 Chain validation failed 的解决方案

最近项目需要适配7.0,发现开始报

Caused by: java.security.cert.CertificateException: Chain validation failed


网络安全性配置 只适用于 targetSdk>23 的应用,但依旧尝试了一番,结果依旧。


再经过google一番,依然无法找到解决方案后,开始了openssl分析 :

openssl s_client -connect 192.168.1.1:8443  -cert path/client.cer -key path/client-key.pem -tls1 -CAfile path/ca.cer

发现在握手过程中报过一次错误,但是并不影响7.0以下建立连接,猜测7.0以后加强了SSL验证环节,任何报错都将导致握手失败。


最后发现-CAfile需要的是证书链而不仅仅是一个root.cer,即必须包含所有证书信息:

-----BEGIN CERTIFICATE----- 
(如: domain.cer) 
-----END CERTIFICATE----- 
-----BEGIN CERTIFICATE----- 
(如: domain1.cer)
-----END CERTIFICATE----- 
..........................
..........................
-----BEGIN CERTIFICATE----- 
(如:root.cer) 
-----END CERTIFICATE-----

同理推断 Android需要在信任证书库生成后加入以下代码:

CertificateFactory cf = CertificateFactory.getInstance("X.509");
InputStream caInput =IApplication.getContext()
                        .getResources().openRawResource(R.raw.ca_c);
Certificate ca_c;
try {
ca_c = cf.generateCertificate(caInput);
} finally {
caInput.close();
}
//注意 这个是信任证书库 ,双向认证的别写在客户端库了
if(ca_c!=null){
trustStore.setCertificateEntry("ca", ca_c);
}


ps:当然也可以使用BC打包证书库(设置密码更安全),注意一定要把整个证书链都依次加入信任证书库。



  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值