VC编译OpenSSL
编译工具准备
- 安装好
Visual Studio
。 - 安装
Perl
, 主要是用来生成nmake的。 - 准备好汇编语言编译工具nasm,并添加到
path
路径。 - 下载好Open SSL源代码。
编译OpenSSL
-
安装
Perl
,并加入到path
路径,检验标标准就是perl
命令可用。 -
检验
nasm
命令可用。 -
选择
VC
编译的版本, 以VS 2022
为例,可以选择多种编译方式,入下图
- 其中
x64 Native Tools Command Prompt for VS 2022
表示使用64
位编译64
位的程序。 - 其中
x64_x86 Cross Tools Command Prompt for VS 2022
表示使用64
的编译程序编译32
位的程序。 - 其中
x86 Native Tools Command Prompt for VS 2022
表示使用x86
的编译工具编译32
位的程序。 - 其中
x86_x64 Cross Tools Command Prompt for VS 2022
表示使用x86
的编译工具编译64
位的程序。
- 其中
-
选择其中一个编译方式,进入控制台,比如选择
x86 Native Tools Command Prompt for VS 2022
.
-
生成
nmake
配置文件, 命令。
shell
# 先进入到openssl 的源码目录中
perl Configure VC_WIN32
- 如果没有安装
nmake
会出现提示, 直接使用perl
的命令安装就好了。
shell
ppm install dmake
- 待安装好了
nmake
之后, 重新进行配置。
shell
perl Configure VC_WIN32
- 待配置文件执行完成之后,
nmake
的配置就生成好了。执行命令开始编译
shell
nmake
- 编译完之后可以直接install
shell
nmake install
- 执行完之后,
Open SSL
会被安装好,具体的安装目录可以查看makefile
文件
shell
# Do not edit these manually. Use Configure with --prefix or --openssldir
# to change this! Short explanation in the top comment in Configure
INSTALLTOP_dev=C:
INSTALLTOP_dir=\Program Files (x86)\OpenSSL
OPENSSLDIR_dev=C:
OPENSSLDIR_dir=\Program Files (x86)\Common Files\SSL
LIBDIR=lib
MODULESDIR_dev=C:
MODULESDIR_dir=\Program Files (x86)\OpenSSL\lib\ossl-modules
ENGINESDIR_dev=C:
ENGINESDIR_dir=\Program Files (x86)\OpenSSL\lib\engines-3
!IF "$(DESTDIR)" != ""
INSTALLTOP=$(DESTDIR)$(INSTALLTOP_dir)
OPENSSLDIR=$(DESTDIR)$(OPENSSLDIR_dir)
ENGINESDIR=$(DESTDIR)$(ENGINESDIR_dir)
MODULESDIR=$(DESTDIR)$(MODULESDIR_dir)
!ELSE
INSTALLTOP=$(INSTALLTOP_dev)$(INSTALLTOP_dir)
OPENSSLDIR=$(OPENSSLDIR_dev)$(OPENSSLDIR_dir)
ENGINESDIR=$(ENGINESDIR_dev)$(ENGINESDIR_dir)
MODULESDIR=$(MODULESDIR_dev)$(MODULESDIR_dir)
!ENDIF
- 等待命令执行完成之后,
Open SSL
就算编译安装完成了。 采用x86
格式编译安装默认路径在C:\Program Files (x86)\OpenSSL
建立Hello World
工程
- 建立一个
Open SSL
工作目录文件夹,例如ssl_code
。 - 将
Open SSL
目录下的bin
lib
include
三个文件夹复制到ssl_code
之下. - 为了能支持不同的平台, 将目前的
bin
lib
目录下在分别创建一个x86
文件夹,并将对应的文件下移到x86
文件夹下。 - 继续在
ssl_code
之下新建一个src
文件夹存放源代码。 - 建立好的目录结构为
shell
└─ssl_code
├─bin
│ └─x86
├─include
│ └─openssl
├─lib
│ └─x86
│ ├─engines-3
│ └─ossl-modules
└─src
创建VS工程
- 创建一个新项目.
- 选择空项目
- 输入项目名称,选择位置位刚才的
src
目录
- 点击
【创建】
项目建立成功。 - 在工程的源文件目录下添加一个
hello_world.cpp
文件. - 选中
001_helloworld
工程右键点击属性
- 在属性配置页面中选择
C/C++
, 在附加目录中配置../../inlude
,制定头文件的路径.
- 因为目前编译的是
x86
格式的Open SSL
, 所以这里的平台选择Win32
。 - 点击
【确定】
完成配置。 - 开始在
hello_world.cpp
文件中编写代码, 我们期望的是完成一个随机数的产生.
c++
#include <iostream>
#include <openssl/rand.h>
#include <time.h>
using namespace std;
int main(int argc, char* argv[])
{
cout << "First openssl code !" << endl;
time_t t = time(0);
unsigned char buf[16] = { 0 };
int re = RAND_bytes(buf, sizeof(buf));
for (int i = 0; i < sizeof(buf); i++)
{
cout << "[" << buf[i] << "]";
}
getchar();
return 0;
}
- 目前如果点击运行
【CTRL+F5】
/F5
是不可以的,原因是没有静态库,编译不能通过。 - 首先需要在链接库上配置链接库的目录,根据项目的目录使用相对路径的形式,附加目录地址为
../../lib/x86
,如下图配置。
- 配置需要关联的静态库,我们需要使用的静态库为
libcrypto.lib
.
- 此时如果之间点击运行会提示找不到对应的动态库
libcrypto-3.dll
。
- 为了方便运行, 将生成的路径直接改到
bin/x86
目录下。 配置如下图输出目录改为../../bin/x86
。
同时把调试的工作目录也改为bin/x86
下, 更改操作如下图所示.
- 此时再次点击运行即可正常运行了。运行结果如下图所示/