Windows下编译openssl库

1、概述

OpenSSL是一个开放源代码的软件库包,它实现了 SSL(Secure SocketLayer)和 TLS(Transport Layer Security)协议,所以应用程序可以使用这个包来进行安全通信,避免窃听,同时确认另一端连接者的身份。这个包广泛被应用在互联网的网页服务器上。

SSL是啥?大家知道我们访问网站的时候,以HTTPS开头的表示你和服务器之间传输的数据经过了加密,这里所使用的加密协议就是SSL(Secure Sockets Layer,后来又推出了它的后续版本,改名叫TLS)。也就是说,把HTTP协议经过一层SSL协议进行加密包装,就变成了HTTPS。当然,SSL/TLS还用在很多协议中,例如VPN、加密的电子邮件协议等。

在SSL协议中,我们使用了很多密码学手段来保护数据,其中包括对称密码、公钥密码、数字签名、证书、完整性校验、伪随机数生成等。由于这些算法和操作都非常复杂,于是开源社区就开发了一套库,这个库里面提供了很多现成的标准方法,其他开发者只要用正确调用这些方法,就可以实现SSL协议中的各种加密/解密操作了。这个库就是开源的OpenSSL库。

如何使用openssl?
一般情况下,直接到 Win32 OpenSSL 上下载已经编译好的 OpenSSL 库使用即可。但在某些情况下,可能需要适当的修改或者裁剪 OpenSSL,那么编译它就成为了一个关键问题。
2、准备工作(win64为例)

1、下载并安装 Visual Studio(以 VS 2013 为例)。

2、下载并安装 ActivePerl,下载地址:http://www.activestate.com/activeperl/downloads ,我下载的版本是5.24.3.2404

安装过程一律选默认即可。

ActivePerl一个perl脚本解释器。其包含了包括有 Perl for Win32、Perl for ISAPI、PerlScript、Perl Package Manager四套开发工具程序,可以让用户编写出适用于unix,windows,linux系统的CGI程序来。

安装的只是perl的一个解释程序啦,外观上也不会发生什么变化,你在windows的cmd界面里输入perl -v可查看你所安装的版本。显示如下图:

3、下载并安装 Nasm 汇编器,下载地址:http://www.nasm.us/ ,我下载的是nasm-2.14-installer-x64.exe

这里安装完成后,将安装目录 C:\Program Files\NASM(以你的安装目录为准) 添加到系统环境变量 Path 中。

配置环境变量:

右键计算机选择属性,选择高级系统设置,选择高级选项,再选择右下方环境变量选项,给系统变量选择新建,变量名随便起不冲突即可(如NASM),变量值填写安装目录(如 C:\Program Files\NASM)

    注:若桌面没有计算机选项的可通过控制面板 — 系统和安全 — 系统到该目录。或开始 — 计算机 — 右键 — 选择属性。

4、下载并安装 OpenSSL,下载地址:https://www.openssl.org/source/ ,我下载的版本是 openssl-1.0.2p.tar.gz

下载完成后,将 OpenSSL 包解压至 C:\openssl-1.0.2p,便可以进行编译了。

注意: 解压后的目录中有两个文件 - INSTALL.W32、INSTALL.W64,包含了 OpenSSL 的各个编译步骤。

注意:当前最新版本为openssl-1.1.1.tar.gz,解压后的目录中并没有INSTALL.W32、INSTALL.W64两个文件,该版本安装方法具体可参考README和INSTALL两个文件。
3、编译OpenSSL
3.1、配置编译环境

我们用VS2013来作为编译工具,使用VS2013对应的命令行进入,操作步骤如下:

开始 — 所有程序 — Visual Studio 2013 — Visual Studio Tools — 选择一个命令提示工具

进入命令提示符,然后定位至OpenSSL的安装目录,如 C:\openssl-1.0.2m

注意:这里不建议使用cmd命令行,使用cmd命令行在执行nmake -f ms\nt.mak编译时,会提示’nmake’ 不是内部或外部命令,也不是可运行的程序。(需要配置环境变量啥的,没有试,这里直接使用VS 2013命令行)
3.2、配置编译文件和模式

输入如下命令:

perl Configure VC-WIN64A no-asm --prefix=F:\openssl

    1

参数说明:
VC-WIN64A表示Windows 64位系统,32位系统请换成VC-WIN32,若要使用debug版本,请使用debug-VC-WIN64A或debug-VC-WIN32
no-asm 表示不用汇编,不设置此属性,可能会导致编译不过(建议使用)
–prefix=F:\openssl将其安装到F盘的openssl文件夹下,省略会安装在默认路径下

显示如下图:

3.3、生成编译配置文件

若为Windows 64位系统,执行

ms\do_win64a.bat

    1

若为Windows 32位系统,执行

ms\do_ms.bat

    1

执行这一步之后,在ms目录下会生成nt.mak和ntdll.mak两个编译配置文件
nt.mak 用于生成静态lib库
ntdll.mak 用于生成动态dll库
3.4、编译

静态库

nmake -f ms\nt.mak    

    1

动态库

nmake -f ms\ntdll.mak

    1

注:这里也可以直接执行如下命令,将静态库或动态库直接安装到指定目录(或默认目录):

//静态库
nmake -f ms\nt.mak install
//或
//动态库
nmake -f ms\ntdll.mak install

    1
    2
    3
    4
    5

3.5、测试

测试静态库:

 nmake -f ms\nt.mak test

    1

测试动态库:

 nmake -f ms\ntdll.mak test

    1

若最终显示 passed all tests 则说明生成的库正确:

3.6、安装

安装静态库:

nmake -f ms\nt.mak install

    1

安装动态库:

nmake -f ms\ntdll.mak install

    1

编译、安装完成后,即可在 F:\openssl目录下看到生成的相关文件和文件夹,如下图:

注:F:\openssl目录为执行 perl Configure VC-WIN64A no-asm --prefix=F:\openssl 时指定的目录,若没有通过–prefix=指定目录,会安装到一个默认目录(命令行内会有提示),如下图显示默认安装到了 C:\usr\local\ 目录


3.7、其他

清除上次静态库的编译,以便重新编译:

nmake -f ms\nt.mak clean

    1

清除上次动态库的编译,以便重新编译:

nmake -f ms\ntdll.mak clean

————————————————
版权声明:本文为CSDN博主「mayue_csdn」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/mayue_web/article/details/83997969

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384915.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Makefile规则介绍

Makefile 一个规则 三要素:目标,依赖,命令 目标:依赖命令 1、第一条规则是用来生成终极目标的规则 如果规则中的依赖不存在,向下寻找其他的规则 更新机制:比较的是目标文件和依赖文件的时间 两个函…

windows环境下C语言socket编程

最近由于实验需要,要求写一个c程序与java程序通信的软件,为了测试首先写了一个windows环境下c语言的socket(tcp)通信程序。 首先socket通信的步骤: 图一 socket通信步骤(转载) 图二 三次握手协议&…

进程控制块(PCB)

进程控制块PCB 我们知道,每个进程在内核中都有一个进程控制块(PCB)来维护进程相关的信息,Linux内核的进程控制块是task_struct结构体。 /usr/src/linux-headers-3.16.0-30/include/linux/sched.h文件中可以查看struct task_struct…

网络层攻击防御

网络层攻击防御 网络层攻击防御主要分为以下三类: TCP类报文攻击防御 UDP类报文攻击防御 ICMP类报文攻击防御 TCP类报文攻击防御 TCP正常的交互过程: 图:TCP正常交互过程 在TCP/IP协议中,TCP协议提供可靠的连接服务&#xff0c…

Linux之环境变量

常见环境变量 按照惯例,环境变量字符串都是namevalue这样的形式,大多数name由大写字母加下划线组成,一般把name的部分叫做环境变量,value的部分则是环境变量的值。环境变量定义了进程的运行环境,一些比较重要的环境变量…

环境变量操作函数

getenv获取环境变量值的函数&#xff1b; setenv改变或者添加环境变量函数&#xff1b; unsetenv 取消环境变量&#xff1b; &#xff08;可以在终端上man 函数名来获取详细的函数信息&#xff09; #include<stdio.h> #include<stdlib.h> #include<string.h>…

Makefile(三)

在平时使用中&#xff0c;可以使用以下的makefile来编译单独的代码 src $(wildcard *.c) obj $(patsubst %.c, %.o, $(src))CC gcc CFLAGS -Wall -gall:$(target)$(target):%:%.c$(CC) $< -o $ $(CFLAGS).PHONY: clean all clean:-rm -rf $(target) 使用方法就是make 后…

位运算(C++)

C输出十六进制 #include<iostream> #include<iomanip> using namespace std;int main() {int a 60;int b 13;int c a &b;cout << "a : hex "<<hex << a << endl;cout << "b : hex "<<hex <<…

数学函数(C/C++)

C中包含头文件<math.h> C包含头文件<cmath> 函数 double cos&#xff08;double&#xff09; 该函数返回弧度角&#xff08;double型&#xff09;的余弦 double tan&#xff08;double&#xff09; 该函数返回弧度角&#xff08;double型&#xff09;的正切…

数据类型(C++)

不同系统会有不同差异&#xff1a; 类型 位(byte) 范围 char 1 -128—127 or 0 – 255 unsigned char 1 0 – 255 signed int 1 -128—127 int 4 -2^31 – 2^32-1 unsigned int 4 0 – 2^32 signed int 4 -2^31 – 2^32-1 short int 2 2^15 – 2^15-1 …

日期与时间(C/C++)

C继承了C语言用于日期和时间操作的结构和函数&#xff0c;使用之前程序要引用<ctime>头文件 有四个与时间相关的类型:clock_t、time_t、size_t、和tm。类型clock_t、size_t、和time_t能够把系统时间和日期表示为某种整数。 结构体tm把时间和日期以C结构的形式保存&#x…

标准输入输出(C++)

输入输出流函数&#xff08;模板&#xff09; #include<iostream> #include<iomanip> using namespace std; int main() {cout << setiosflags(ios::left|ios::showpoint); //设左对齐cout.precision(5); //设置除小数…

拷贝函数和构造函数

类的构造函数&#xff1a; 类的构造函数是类的一种特殊的成员函数&#xff0c;它会在每次创建类的新对象时执行。 构造函数的名称与类的名称是完全相同的&#xff0c;并且不会返回任何类型&#xff0c;也不会返回void。 构造函数可用于为某些成员变量初始值。 默认的构造函数是…

拷贝构造函数

拷贝构造函数是一种特殊的构造函数&#xff0c;它在创建对象时&#xff0c;使用的是同一类中之前创建的对象来初始化新创建的对象。拷贝构造函数通常用于&#xff1a; l 通过使用另一个同类型的对象来初始化新创建的对象&#xff1b; l 复制对象把它作为参数传递给函数&#…

Linux进程通信之管道

进程间完成数据传递需要借助操作系统提供的特殊的方法&#xff0c;比如&#xff1a;文件、管道、信号、共享内存、消息队列、套接字、命名管道等。但现在常用的进程间通信方式有&#xff1a; 管道 – 使用最简单 pipe 管道一般读写行为 FIFO&#xff08;有名管道&#xff09;&a…

Linux进程通信之文件

父子进程共享打开的文件描述符------使用文件完成进程间通信. /*** fork_share_fd.c***/ #include <stdio.h> #include <unistd.h> #include <string.h> #include <stdlib.h> #include <fcntl.h> #include <sys/wait.h>int main(void) {in…

dup2函数

将当前系统中的进程信息打印到文件中 命令行&#xff1a;ps aux > out 将ps得到的信息重定向到out文件中 使用dup2文件在程序中完成。 int dup2(int oldfd,int newfd); /*** dup2.c ***/ #include<stdio.h> #include<fcntl.h> #include<unistd.h> #includ…

wait()函数

wait()函数&#xff1a;回收僵尸进程 父进程调用wait函数可以回收子进程终止信息。该函数有三个功能&#xff1a; 1&#xff09; 阻塞等待子进程退出 2&#xff09; 回收子进程残留资源 3&#xff09; 获取子进程结束状态&#xff08;退出原因&#xff09; /*** zoom_test.c **…

waitpid()函数

waitpid函数 作用同于wait&#xff0c;但可指定pid进程清理&#xff0c;可以不阻塞。 pid_t waitpid(pid_t pid,int *status,int options);成功&#xff1a;返回清理掉的子进程ID&#xff1b;失败&#xff1a;-1&#xff08;无子进程&#xff09; 特殊参数和返回情况&#xff1…

孤儿进程、僵尸进程

孤儿进程&#xff1a;父进程先于子进程结束&#xff0c;则子进程成为孤儿进程&#xff0c;子进程的父进程成为init进程&#xff0c;称为init进程领养孤儿进程。 /*** orphan.c ***/ #include <stdio.h> #include <unistd.h> #include <sys/wait.h>int main(v…