是否有一种方法可以使用一组合理的可信CA证书来设置OpenSSL上下文(SSL_CTX
),而无需自己分发它们?我不想让他们跟上时代的步伐。国际海事组织的任何现代操作系统都应该提供“为我提供可信的CA证书”作为服务,但我不知道是否真的是这样。
我不介意编写这段代码三次(一次是针对Windows,一次是针对Mac,一次是针对Linux),但我更愿意将其限制在这一点上。特别是,我不想尝试编写一些代码来窥探安装了哪些浏览器,并试图提取它们所信任的证书。(显然是很容易搞错。)
最近版本的Linux的答案似乎是用/etc/ssl/certs/ca-certificates.crt
调用/etc/ssl/certs/ca-certificates.crt
(如果存在该文件)。
Windows和Mac有简单的答案吗?
发布于 2012-04-26 12:38:20
您可以使用“剧本”从Mozilla (从Curl's维护者的回答)转换列表。根据它的代码的说法,在包含证书之前,它似乎要检查证书是否可信。
发布于 2013-10-26 13:36:49
以下是我最后所做的:
在Windows上:使用CertOpenSystemStore
从WindowsCertOpenSystemStore
证书存储中获取证书,使用CertEnumCertificatesInStore
循环它们,从CERT_CONTEXT
的pbCertEncoded
字段获取X 509编码的原始证书,使用d2i_X509
创建OpenSSL X509
结构,并使用X509_STORE_add_cert
将其添加到OpenSSL证书存储中。Windows函数都可以从crypt32.dll
中获得。
在Mac上:使用"/System/Library/Keychains/SystemRootCertificates.keychain"
从SecKeychainOpen
密钥链获取证书,使用SecKeychainSearchCreateFromAttributes
为密钥链中的证书创建迭代器,使用SecKeychainSearchCopyNext
迭代,使用SecItemExport
获取原始X509证书,使用d2i_X509
创建OpenSSL证书,并使用X509_STORE_add_cert
将其添加到OpenSSL存储中。Mac函数可以从/Systems/Library/Frameworks/Security.framework/Security
中获得。
更好的方法可能是创建一个带有回调的OpenSSL X509_STORE
,该回调使用OS函数来验证单个根证书,而不是将它们全部复制过来,但我还没有尝试过。
发布于 2012-04-26 12:30:53
在OS上,您可以从用户的密钥链中获得用户信任的证书的信息。这里有一个链接,其中包含了一些关于使用Cocoa收集该信息的非常好的信息:
如果Cocoa不是满足您需求的ok依赖项,并且您想直接从命令行执行所有操作,那么可以使用certtool
实用工具--参见man certtool
和其他在线文档来了解它。若要列出用户登录密钥链中的所有证书,请执行以下操作:
certtool y k=login.keychain
或者获取内置的受信任系统根的列表:
certtool y k=/System/Library/Keychains/SystemRootCertificates.keychain
也许
certtool y k=/System/Library/Keychains/SystemCACertificates.keychain
我确信还有其他方法可以使用系统接口来获取这些信息。
在Linux方面,是的,/etc/ssl/certs/ca-certificates.crt
是正确的选择。当安装ca-certificates
包时,该文件将存在于Debian衍生产品(inc. Ubuntu变体)上,我不知道如何在基于红帽子的系统中正确地实现该文件。
https://stackoverflow.com/questions/10095676
复制相似问题