Can OpenSSL on Windows use the system certificate store?(Windows 上的 OpenSSL 可以使用系统证书存储吗?)
问题描述
我从 Linux 移植到 Windows 的一些工作 C++ 代码在 Windows 上失败,因为 SSL_get_verify_result()
正在返回 X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY
.
Some working C++ code that I'm porting from Linux to Windows is failing on windows because SSL_get_verify_result()
is returning X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY
.
该代码在 Linux 上使用 SSL_CTX_set_default_verify_paths()
来告诉 SSL 只查看证书存储的标准默认位置.
The code was using SSL_CTX_set_default_verify_paths()
on Linux to tell SSL to just look in the standard default locations for the certificate store.
是否可以让 OpenSSL 使用系统证书存储?
Is it possible to get OpenSSL to use the system certificate store?
推荐答案
我之前做过.希望这会有所帮助,如果这正是您正在寻找的.p>
I have done it earlier. Hope this helps, if this is exactly what you are looking for.
- 使用加密 API 从 Windows 证书存储中加载您的证书(在
PCCERT_CONTEXT
结构中). - 以二进制格式获取它的加密内容.[
PCCERT_CONTEXT->pbCertEncoded
]. - 使用 OpenSSL 的
d2i_X509()
方法将此二进制缓冲区解析为 X509 证书对象. - 使用
SSL_CTX_get_cert_store()
方法获取 OpenSSL 信任存储的句柄. - 使用
X509_STORE_add_cert()
方法将上面解析的 X509 证书加载到此信任存储中. - 大功告成!
- Load your certificate (in
PCCERT_CONTEXT
structure) from Windows Cert store using Crypto APIs. - Get encrypted content of it in binary format as it is. [
PCCERT_CONTEXT->pbCertEncoded
]. - Parse this binary buffer into X509 certificate Object using OpenSSL's
d2i_X509()
method. - Get handle to OpenSSL's trust store using
SSL_CTX_get_cert_store()
method. - Load above parsed X509 certificate into this trust store using
X509_STORE_add_cert()
method. - You are done!
这篇关于Windows 上的 OpenSSL 可以使用系统证书存储吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Windows 上的 OpenSSL 可以使用系统证书存储吗?


基础教程推荐
- 常量变量在标题中不起作用 2021-01-01
- C++结构和函数声明。为什么它不能编译? 2022-11-07
- 如何将 std::pair 的排序 std::list 转换为 std::map 2022-01-01
- 静态库、静态链接动态库和动态链接动态库的 .lib 文件里面是什么? 2021-01-01
- 如何通过C程序打开命令提示符Cmd 2022-12-09
- 如何在 C++ 中初始化静态常量成员? 2022-01-01
- 如何检查GTK+3.0中的小部件类型? 2022-11-30
- 在 C++ 中计算滚动/移动平均值 2021-01-01
- 我有静态或动态 boost 库吗? 2021-01-01
- 这个宏可以转换成函数吗? 2022-01-01