Windows下OpenSSL的下载,安装,环境变量配置,以及基于Visual Stdio项目的配置
一、下载
下载链接:https://slproweb.com/products/Win32OpenSSL.html
本文下载的是.exe版本
二、安装
1. 与安装其他程序相同,在安装时需要记下将安装路径,以备配置环境变量或者VS项目使用。本文安装路径为:D:\Program Files\OpenSSL-Win64。
2.如下图所示,需要选中第二条(将OpenSSL DLLS文件复制到OpenSSL的bin目录中),这样有利于环境变量和VS的配置。

3. 安装完成之后,OpenSSL的安装目录下的文件为:

三、 环境变量配置
1. 配置环境变量过程如下图所示,①可以利用搜索框搜索“环境变量”打开。其中新建的环境变量的内容即为OpenSSL安装路径下的bin目录。
本文的路径为:D:\Program Files\OpenSSL-Win64\bin

2.测试环境变量是否配置成功:cmd打开命令框,执行命令:opensll version,如下图所示,如果可以给出OpenSSL的版本即可证明已成功安装并成功配置环境变量。
四、 基于Visual Stdio项目配置OpenSSL
1.右键点击C语言项目,并打开“属性”,如下图所示。


2. 将所安装的OpenSSL的include路径添加到包含目录中,本文的include路径为:D:\Program Files\OpenSSL-Win64\include(文件夹如下图所示)。

具体步骤为:C/C++ -> 常规 -> 附加包含目录,然后把include目录添加到附加包含目录即可。如下图所示。

3. 将lib路径添加到库目录。
本文安装的OpenSSL的lib目录下,有四个文件夹,且均含有为libcrypto.lib文件。如下所示。

它们四个的不同点在于:
MD(多线程 DLL 版本)用于 Release 模式。MDd(多线程 DLL 版本,调试)用于 Debug 模式。MT(多线程静态版本)用于 Release 静态链接。MTd(多线程静态版本,调试)用于 Debug 静态链接。
具体选用哪个lib目录,可根据自己情况选择
- 对于 Debug 模式:
- 多线程 DLL:
D:\Program Files\OpenSSL-Win64\lib\VC\x64\MDd - 多线程静态:
D:\Program Files\OpenSSL-Win64\lib\VC\x64\MTd
- 多线程 DLL:
- 对于 Release 模式:
- 多线程 DLL:
D:\Program Files\OpenSSL-Win64\lib\VC\x64\MD - 多线程静态:
D:\Program Files\OpenSSL-Win64\lib\VC\x64\MT
- 多线程 DLL:
它们的特征如下:
-
Debug vs. Release 模式:
- Debug 模式用于开发和调试,通常带有调试符号,执行速度较慢。
- Release 模式用于发布和生产环境,优化代码,执行速度较快。
-
动态链接 vs. 静态链接:
- 动态链接(MD 和 MDd):生成的可执行文件较小,因为共享了运行时库,但需要在目标系统上存在相应的 DLL 文件。
- 静态链接(MT 和 MTd):生成的可执行文件较大,因为所有运行时库都包含在可执行文件中,不需要依赖外部 DLL 文件。
本文选择的是“多线程静态:D:\Program Files\OpenSSL-Win64\lib\VC\x64\MTd”
将lib路径添加到库目录的步骤为:链接器 -> 常规 -> 附加库目录,然后将选择的lib路径添加到附加库目录中。如下图所示。
4. 链接OpenSSL库。常用的库为libcrypto.lib和libssl.lib
具体步骤为:链接器 -> 输入 -> 附加依赖项,然后将libcrypto.lib;libssl.lib添加到附加依赖项。如下图所示。

5. 至此即配置完成,可以用下面这个C语言项目检测一下,配置是否成功
#include <openssl/ssl.h>
#include <openssl/err.h>
#include <stdio.h>
#include <string.h>
int main() {
// 初始化 OpenSSL 库
SSL_library_init();
SSL_load_error_strings();
OpenSSL_add_all_algorithms();
// 简单的 OpenSSL 操作以验证配置
const char* text = "Hello, OpenSSL!";
unsigned char md[EVP_MAX_MD_SIZE];
unsigned int md_len;
EVP_MD_CTX* mdctx = EVP_MD_CTX_new();
if (mdctx == NULL) {
printf("Failed to create EVP_MD_CTX\n");
return 1;
}
if (1 != EVP_DigestInit_ex(mdctx, EVP_sha256(), NULL)) {
printf("EVP_DigestInit_ex failed\n");
EVP_MD_CTX_free(mdctx);
return 1;
}
if (1 != EVP_DigestUpdate(mdctx, text, strlen(text))) {
printf("EVP_DigestUpdate failed\n");
EVP_MD_CTX_free(mdctx);
return 1;
}
if (1 != EVP_DigestFinal_ex(mdctx, md, &md_len)) {
printf("EVP_DigestFinal_ex failed\n");
EVP_MD_CTX_free(mdctx);
return 1;
}
EVP_MD_CTX_free(mdctx);
printf("SHA-256 digest of '%s':\n", text);
for (unsigned int i = 0; i < md_len; i++) {
printf("%02x", md[i]);
}
printf("\n");
// 清理 OpenSSL 库
EVP_cleanup();
ERR_free_strings();
return 0;
}
正确的运行结果如下图所示。

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。
更多推荐


所有评论(0)