Java HTTPS 请求失败排查与证书导入全过程

文章目录


Java HTTPS 请求失败排查与证书导入全过程

在实际项目部署中,我们可能会遇到 Java 应用调用某个 HTTPS 接口失败,特别是涉及公司网关(如 www.test.com)或 WAF 防护设备时,问题常常集中在 SSL/TLS 证书验证失败上。本文记录一次完整的排查过程,并给出相关知识点补充。


问题背景

Java 应用通过 java.net.HttpURLConnection 或 RestTemplate 等方式请求接口 https://www.test.com,却出现如下异常:

复制代码
javax.net.ssl.SSLHandshakeException: 
sun.security.validator.ValidatorException: PKIX path building failed: 
sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

问题初步分析

该错误表明 Java 无法信任目标服务的 HTTPS 证书。常见原因有:

  • 服务端证书是自签名(Self-signed)
  • 服务端证书链不完整
  • Java SDK 默认的 cacerts 信任库中缺少对应根证书或中间证书

特别注意:Java 不使用系统证书库 ,而是依赖其内置的 cacerts 信任库。


排查过程

查看目标地址证书

bash 复制代码
openssl s_client -connect www.test.com:443 -showcerts

可以看到目标返回了一整套证书链,包括:

  • 服务器证书(.crt)
  • 中间证书(可能有多个)
  • 根证书(部分环境不提供)

导入证书

你可能收到运维/安全团队提供的证书文件,如:

text 复制代码
www.test.com_public.crt
www.test.com_chain.crt
www.test.com.key

我们只需要 .crt 文件,通常导入 www.test.com_chain.crt 即可。

导入命令如下(以 JDK 默认 cacerts 为例):

bash 复制代码
keytool -importcert \
  -trustcacerts \
  -alias test-gateway \
  -file www.test.com_chain.crt \
  -keystore $JAVA_HOME/lib/security/cacerts \
  -storepass changeit

验证证书是否导入成功

bash 复制代码
keytool -list -keystore $JAVA_HOME/lib/security/cacerts -storepass changeit | grep duola

输出示例:

复制代码
test-gateway, Jul 31, 2025, trustedCertEntry,

重启应用

bash 复制代码
# 这是走默认的cacerts信任库
java -jar my-test-project-0.0.1-SNAPSHOT.jar
# 下边是指定我们导入的信任库
java -Djavax.net.ssl.trustStore=$JAVA_HOME/lib/security/cacerts -Djavax.net.ssl.trustStorePassword=changeit -jar my-test-project-0.0.1-SNAPSHOT.jar

此时如果请求成功,即可初步判定问题解决。


进一步验证:是否真的是证书问题?

如果你怀疑是 WAF、CDN 等中间设备阻断,可以用两种方式验证:

1. 浏览器访问

浏览器访问 https://www.test.com 是否提示 "证书不受信任"?如果没有,一般说明服务器证书链是完整的,但 Java 环境中仍然缺少相应的中间证书。

2. 抓包工具验证(如 Charles、Wireshark)

查看 TLS 握手过程是否被中断或中间设备返回自定义证书。


补充知识点

✅ Java 中默认信任库在哪里?

  • 路径:$JAVA_HOME/lib/security/cacerts
  • 默认密码:changeit

✅ 如果要删除已导入证书?

bash 复制代码
keytool -delete -alias test-gateway -keystore $JAVA_HOME/lib/security/cacerts -storepass changeit

✅ 可否使用浏览器导出证书?

可以。在浏览器中点击锁图标 → 查看证书 → 导出为 .crt 文件,然后再导入 Java 信任库。


总结

这次排查证明:

Java HTTPS 请求失败,通常不是网络或 WAF 问题 ,而是 Java 缺少可信证书链中的中间证书

解决方法也非常明确:

  1. 获取目标服务的完整证书链
  2. 将链中缺失的证书导入 Java 的 cacerts 信任库
  3. 重启应用验证是否成功

如果你在实际部署中也遇到类似问题,不妨从证书入手,按图索骥逐步排查。

生产上解决

证书等级提升,开始是从阿里云上够买个人免费版证书,提升证书等级就行了


相关推荐
Lionel_SSL2 小时前
《深入理解Java虚拟机》第三章读书笔记:垃圾回收机制与内存管理
java·开发语言·jvm
记得开心一点嘛2 小时前
手搓Springboot
java·spring boot·spring
老华带你飞3 小时前
租房平台|租房管理平台小程序系统|基于java的租房系统 设计与实现(源码+数据库+文档)
java·数据库·小程序·vue·论文·毕设·租房系统管理平台
独行soc3 小时前
2025年渗透测试面试题总结-66(题目+回答)
java·网络·python·安全·web安全·adb·渗透测试
脑子慢且灵3 小时前
[JavaWeb]模拟一个简易的Tomcat服务(Servlet注解)
java·后端·servlet·tomcat·intellij-idea·web
华仔啊4 小时前
SpringBoot 中 6 种数据脱敏方案,第 5 种太强了,支持深度递归!
java·后端
异常驯兽师5 小时前
Spring 中处理 HTTP 请求参数注解全解析
java·spring·http
连合机器人6 小时前
晨曦中的守望者:当科技为景区赋予温度
java·前端·科技
AD钙奶-lalala6 小时前
idea新建的项目new 没有java class选项
java·ide·intellij-idea
sheji34166 小时前
【开题答辩全过程】以 12306候补购票服务系统为例,包含答辩的问题和答案
java·eclipse