爱琴孩 2019-12-01 17:14 采纳率: 0%
浏览 1711
已结题

jdk中的jre/lib/security目录下为啥要导入证书

之前项目中用httpclient调用第三方接口,走的是https,之前正常运行。后来测试把测试环境的jdk换成了openjdk,后运行报错
报错信息如下

java.lang.RuntimeException: javax.net.ssl.SSLException: java.lang.RuntimeException: Unexpected error: java.security.InvalidAlgorithmParameterException: the trustAnchors parameter must be non-empty

后来排查发现之前jdk的jre/lib/sercurity目录下有cer证书,而新安装的openjdk目录下没有证书,后来把jdk目录下证书拷贝到openjdk目录下,就好了。
想确认下这个证书的作用是什么。是不是可以认为就好比浏览器访问https需要导入证书。

  • 写回答

3条回答

  • 毕小宝 博客专家认证 2019-12-01 17:31
    关注

    因为不同的 jdk 工具实现的加密工具的程度不同,可能提供的加密工具包也不一样。
    比如 windows 和 Linux 相同版本的 jdk 的 https 加密算法包和策略也是不一样的。
    楼主所说的证书中包含了 https 通信过程中需要的认证配置信息,可能这个第三方接口有自己的加密要求,且有自己发布的证书,所以需要导入。
    有些 https 访问其实使用了默认的 https 证书,所以不需要再导入的吧。

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器