https 证书过期问题排查

在将服务协议从HTTP迁移到HTTPS时遇到SSLHandshakeException,原因是服务器的证书链中存在过期证书。解决方案包括禁用SSL证书校验、更新OpenSSL库版本和更新服务端证书。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、问题描述

在服务协议由 http 迁移至 https 时,我发现线上环境报错

javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path validation failed: java.security.cert.CertPathValidatorException: timestamp check failed
Caused by: java.security.cert.CertificateExpiredException: NotAfter: Sat May 30 18:48:38 CST 2020

二、问题排查

根据报错 CertificateExpiredException: NotAfter: Sat May 30 18:48:38 CST 2020 是因为证书过期,我立即联系客户技术部确认他们的证书是否过期,经查证没有过期

但是在生产和测试环境都报证书过期错误,奇怪的是本地环境可以正常访问

于是我在 https://whatsmychaincert.com/ 验证其证书链是否有问题,果然经查证其证书链中有过期的证书:

所以原因定位在客户服务器的证书链中存在过期证书

三、什么是证书链

简单来说,当客户端访问 TLS 服务器时,服务端会发送一个证书给客户端来证明其身份,客户端需要构建一条由服务端证书到根证书的证书链,以便对其进行验证。服务端很贴心,帮客户端返回了一条证书链

如果服务端的证书链是这个样子:

### 如何解决Charles证书过期问题 当遇到Charles证书过期的情况时,可以通过一系列措施来恢复其正常功能。对于不同操作系统上的处理方式略有差异。 #### macOS/iOS平台解决方案 在macOS环境下,面对Charles证书过期问题,应当采取以下行动: - 打开Charles应用程序,并通过菜单栏中的`Help`选项进入`SSL Proxying`子项下的`Reset Charles Root Certificate...`命令完成根证书的重置工作[^1]。 一旦执行上述操作之后,可能会注意到之前设置好的HTTPS流量捕获不再有效,这是因为旧版的安全凭证已失效。此时应前往系统的“钥匙串访问”工具内查找对应的过期条目并将其移除,随后重复之前的步骤重新导入最新的CA文件[^2]。 为了确保新的认证机构被系统认可,在“钥匙串访问”的界面里定位到刚加入的信任对象,右键单击它并选择编辑属性,将验证状态更改为“始终信任”。 另外一种情况是在本地存储介质未能自动同步最新版本的情况下,则需手动导出私钥连同公钥一并通过`Help -> SSL Proxying -> Export Charles Root Certificate and Private Key`路径获取,并按照指引保存至合适位置后再行加载[^4]。 针对iOS设备而言,除了要保证电脑端已完成前述准备工作外,还需额外注意客户端部分的操作流程——即利用移动网络浏览器访问由官方提供的特定链接(通常是<http://chls.pro/ssl>),以此下载适用于该型号终端的新一轮授权证明材料;接着依照屏幕指示逐步推进直至成功激活服务[^5]。 #### Windows平台解决方案 而在Windows环境中,同样遵循类似的思路来进行修复作业: - 启动Charles程序后,参照导航顺序依次点击`Help`>`SSL Proxying`>`Reset Charles Root Certificate`以清除现有的记录并准备接收更新后的密钥集[^3]; 紧接着便是实施新一轮的安装过程:依旧是从顶部菜单选取相应的辅助项目,不过这次的目标变成了`Install Charles Root Certificate`,遵照界面上给出的文字说明一步步落实下去直到结束为止。 假使初次尝试未果或是遇到了其他阻碍因素妨碍了预期效果达成的话,不妨试着先行清理掉残留的数据痕迹再试一次。此外还可以考虑调整代理服务器的相关参数设定,比如借助于`Proxy->SSL Proxying Settings`这一入口添加必要的例外规则等手段加以优化改进。 综上所述,无论是哪种类型的计算装置遭遇此类状况都无需过分担忧,只要严格按照既定的方法逐一排查就能顺利解决问题
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值