【OpenSSL】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配置文件, 命令。

# 先进入到openssl 的源码目录中
perl Configure VC_WIN32

OpenSSL环境

  • 如果没有安装nmake 会出现提示, 直接使用perl的命令安装就好了。
ppm install dmake
  • 待安装好了nmake之后, 重新进行配置。
perl Configure VC_WIN32
  • 待配置文件执行完成之后, nmake的配置就生成好了。执行命令开始编译
nmake
  • 编译完之后可以直接install
nmake install 
  • 执行完之后,Open SSL 会被安装好,具体的安装目录可以查看makefile文件
# 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工程

  1. 建立一个Open SSL工作目录文件夹,例如ssl_code
  2. Open SSL目录下的bin lib include三个文件夹复制到ssl_code之下.
  3. 为了能支持不同的平台, 将目前的bin lib目录下在分别创建一个x86文件夹,并将对应的文件下移到x86文件夹下。
  4. 继续在ssl_code之下新建一个src文件夹存放源代码。
  5. 建立好的目录结构为
└─ssl_code
    ├─bin
    │  └─x86
    ├─include
    │  └─openssl
    ├─lib
    │  └─x86
    │      ├─engines-3
    │      └─ossl-modules
    └─src

创建VS工程

  1. 创建一个新项目.
    在这里插入图片描述
  • 选择空项目
  • 输入项目名称,选择位置位刚才的src目录
    在这里插入图片描述
  • 点击【创建】项目建立成功。
  • 在工程的源文件目录下添加一个hello_world.cpp文件.
  • 选中001_helloworld工程右键点击属性
    在这里插入图片描述
  • 在属性配置页面中选择C/C++, 在附加目录中配置../../inlude,制定头文件的路径.
    在这里插入图片描述
  • 因为目前编译的是x86格式的Open SSL, 所以这里的平台选择Win32
  • 点击【确定】完成配置。
  • 开始在hello_world.cpp文件中编写代码, 我们期望的是完成一个随机数的产生.

#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下, 更改操作如下图所示.
    在这里插入图片描述
  • 此时再次点击运行即可正常运行了。运行结果如下图所示/
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值