栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

来自CA的PKCS12 Java密钥库和Java中的用户证书

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

来自CA的PKCS12 Java密钥库和Java中的用户证书

PKCS#12格式用于存储与证书链关联的私钥,并且两者都是必需的(尽管您可能不需要整个链)。尽管

PKCS12
密钥库类型在将这种格式映射到Java方面做得很好
KeyStore
,但是由于这个原因,并非所有内容都受支持。

您第一次尝试要做的是自己存储证书,这是行不通的。

第二次尝试(

ks.setKeyEntry("SomeAlias", userCert.getPublicKey().getEnpred(),chain)
)中要执行的操作是使用公钥代替应该是私钥的东西(请参阅参考资料
KeyStore#setKeyEntry
)。

.cer
文件通常仅用于证书而不是私钥(当然,扩展名最终仅是一种指示)。如果
.cer
Keychain Access.app
导出文件,则不会获得私钥(这就是
.p12
导出格式的用途)。

编辑 有关KeychainStore的内容:

如果您尝试进行此转换的原因最终是访问钥匙串中已存在的私钥和证书,则可以

KeychainStore
直接从中加载它们:

KeyStore ks = KeyStore.getInstance("KeychainStore", "Apple");ks.load(null, "-".toCharArray());

一些注意事项:

  • 任何非空,非空的密码都将使用私钥(例如
    "-".toCharArray()
    ),因为访问将由操作系统的安全服务提示(就像在其他应用程序中一样)。
  • 据我所知,仍然存在一个错误,它仅允许访问一个私钥/证书对(即使钥匙串中存在许多对私钥/证书对)


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/437685.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号