微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么Java同时具有cacerts和jssecacerts文件?

如何解决为什么Java同时具有cacerts和jssecacerts文件?

| 我对
cacerts
jssecacerts
文件间的区别感到困惑。 我知道认情况下,java查找
jssecacerts
文件,然后是
cacerts
文件。 但是“ 1”文件的意义是什么? 我的理解是,如果需要使用新的信任库,则应制作一个“ 0”的副本,并将所有新的受信任的CA添加到该副本中。然后,“ 7”系统属性将引用“ 0”的副本(带有新的CA)。这样一来,在该计算机上运行的其他Java应用程序就不会意外地信任非认CA。

解决方法

从Java™安全套接字扩展(JSSE)参考指南中,
TrustManagerFactory
使用以下步骤尝试查找信任材料: 系统属性
javax.net.ssl.trustStore
java-home/lib/security/jssecacerts
java-home/lib/security/cacerts
(默认发货) 我认为这是基于约定而不是配置概念的。无需额外的编码工作,将使用
cacert
。对于额外的私有CA /签名证书,开发人员可以使用第一种或第二种方法,其中前者可能仅包含特定证书,而后来包含证书列表。,据我了解,“ 0”文件是出厂默认文件。 如果存在
jssecacerts
文件,则仅使用-0ѭ文件。 我的建议:保留
cacerts
文件,将其复制到
jssecacerts
,然后向
jssecacerts
文件添加所需的任何专用CA /签名证书。,好问题。我认为这源于JSSE曾经是附加组件的历史事实。 JSSE确实允许多个提供程序,因此maybe1ѭ仅适用于JSSE提供程序,其他提供程序可能使用它们自己的。 但是谁在JSSE之前使用cacerts是另一个问题。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。