From: https://blog.csdn.net/shenyou198/article/details/79771787
如何在 Windows 下编译 OpenSSL (VS2010 使用 VC10 的 cl 编译器)
1、安装 ActivePerl// 初始化的时候, 需要用到 perl 解释器
2、使用 VS2010 下的 Visual Studio 2010 Command Prompt 进入控制台模式(这个模式会自动设置各种环境变量)
3、解压缩 openssl 的包, 进入 openssl 的目录
4、perl configure VC-WIN32
尽量在这个目录下执行该命令,否则找不到 Configure 文件,或者指定完整的 Configure 文件路径。
5、ms\do_ms.bat
在解压目录下执行 ms\do_ms.bat 命令
6、nmake -f ms\ntdll.mak
7、nmake -f ms\nt.mak
编译后
在 openssl 解压目录下执行,完成编译后。输出的文件在 out32dll (6), out32 (7) 里面,包括应用程序的可执行文件、lib 文件和 dll 文件
注意:在运行第五步时,cl 编译器会抱怨说.\crypto\des\enc_read.c 文件的 read 是 The POSIX name for this item is deprecated(不被推荐的),建议使用_read。呵呵,我可不想将 OpenSSL 中的所有的 read 函数修改为_read。再看 cl 的错误代码 error C2220,于是上 MSDN 上查找:
warning treated as error - no object file generated
/WX tells the compiler to treat all warnings as errors. Since an error occurred, no object or executable file was generated.
是由于设置了 / WX 选项,将所有的警告都作为错误对待,所以。。。
于是打开 OpenSSL 目录下的 MS 目录下的 ntdll.mak 文件,将 CFLAG 的 / WX 选项去掉,存盘。。。
继续执行 nmake -f ms\ntdll.mak
一、编译并安装 OpenSSL
1、按照标准步骤从源代码编译安装 OpenSSL
在编译 OpenSSL 前,需要正确安装 Perl,因为在编译 OpenSSL 时需要使用到该程序。
下载最新版本的 Perl 然后安装之。
下载最新版本的 OpenSSL
然后将源码解压缩到某个目录(如 C:\openssl-0.9.8j)中。
进入 openssl 源码目录。
cd c:\openssl-1.0.1e
以下为参照该目录下的文件 INSTALL.W32 的执行过程:
运行 configure:
perl Configure VC-WIN32
创建 Makefile 文件:
ms\do_ms.bat
编译动态库:
nmake -f ms\ntdll.mak
编译静态库:
nmake -f ms\nt.mak
测试动态库:
nmake -f ms\ntdll.mak test
测试静态库:
nmake -f ms\nt.mak test
安装动态库:
nmake -f ms\ntdll.mak install
安装静态库:
nmake -f ms\nt.mak install
清除上次动态库的编译,以便重新编译:
nmake -f ms\ntdll.mak clean
清除上次静态库的编译,以便重新编译:
nmake -f ms\nt.mak clean
2、如果嫌麻烦,不想编译,可以直接用别人做好的 windows OpenSSL 安装包(我用的是 0.9.8j 版),
可以下载 OpenSSL for Windows,直接安装。
P.S. OpenSSL for Windows 的源代码有一些数据类型和 VC6 的编译器不兼容,我发现的不兼容的数据类型如下:
在 OpenSSL 安装目录的下的 include/bn.h 文件中,将
#define BN_ULLONG unsigned long long
#define BN_ULONG unsigned long long
#define BN_LONG long long
分别修改为:
#define BN_ULLONG ULONGLONG
#define BN_ULONG ULONGLONG
#define BN_LONG LONGLONG
否则,会出现编译错误。
二、使用 OpenSSL
在 VC 中配置使用以上的函数库:
点击菜单:Tools -> Options,弹出对话框 “Options”,在该对话框中选择 “Directories” 标签。
在 “Show directories for:” 的 “Include files” 选项中新增目录 “C:\openssl\include”;
“Library files” 选择中新增目录 “C:\openssl\lib”。
然后在需要链接 OpenSSL 函数库的工程中加入如下两句:
#pragma comment(lib, “ssleay32.lib”)
#pragma comment(lib, “libeay32.lib”)
其作用是将 OpenSSL 所需的库导入工程中。
三、问题
我在链接 OpenSSL 的静态函数库时遇到类似以下的问题:
Linking…
msvcrt.lib(MSVCRT.dll) : error LNK2005: _strchr already defined in libcmtd.lib(strchr.obj)
…
这是由于 OpenSSL 的静态函数库使用的是了 VC 的多线程 DLL 的 Release 版本,而我的程序使用了多线程静态链接的 Release 版本。
调整 OpenSSL 的静态函数库使用的库函数版本即可,调整过程如下:
编辑文件 ms\nt.mak,将该文件第 19 行
"CFLAG= /MD /Ox /O2 /Ob2 /W3 /WX /Gs0 /GF /Gy /nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DDSO_WIN32 -D_CRT_SECURE_NO_DEPRECATE -
D_CRT_NONSTDC_NO_DEPRECATE /Fdout32 -DOPENSSL_NO_CAMELLIA -DOPENSSL_NO_SEED -DOPENSSL_NO_RC5 -DOPENSSL_NO_MDC2 -DOPENSSL_NO_TLSEXT -DOPENSSL_NO_KRB5 -
DOPENSSL_NO_DYNAMIC_ENGINE”
中的 “/MD” 修改为 “/MT”。然后重新编译安装 OpenSSL 即可。
四、附录:在 VC 中对 C/C++ 运行时库不同版本编译指令说明
《在 VC 中对 C/C++ 运行时库不同版本编译指令说明》一文中详细介绍了连接不同版本库的编译指令如下:
C Runtime Library:
/MD MSVCRT.LIB 多线程 DLL 的 Release 版本
/MDd MSVCRTD.LIB 多线程 DLL 的 Debug 版本
/MT LIBCMT.LIB 多线程静态链接的 Release 版本
/MTd LIBCMTD.LIB 多线程静态链接的 Debug 版本
/clr MSVCMRT.LIB 托管代码和非托管代码混合
/clr:pure MSVCURT.LIB 纯托管代码
C++ Standard Library:
/MD MSVCPRT.LIB 多线程 DLL 的 Release 版本
/MDd MSVCPRTD.LIB 多线程 DLL 的 Debug 版本
/MT LIBCPMT.LIB 多线程静态链接的 Release 版本
/MTd LIBCPMTD.LIB 多线程静态链接的 Debug 版本
一 配置编译参数
配置编译参数是进行 OpenSSL 编译的第一步, 这一步可以确定系统的环境, 使用什么编译器, 默认安装路径以及其他一些选项. 步骤如下:
- 安装 perl: 下载 ActivePerl-5.8.8.822-MSWin32-x86-280952.msi, 然后点击 msi 文件进行安装!
2.. 配置编译参数: 下载 openssl-1.0.1e.tar.gz, 解压.
vc: 首先在 C:\Program Files\Microsoft Visual Studio .NET 2010\VC10\bin \ 目录下执行 vcvars32.bat, 然后在解压后的 openssl-1.0.1e 目录, 执行命令配置编译参数: perl Configure VC-WIN32
bc: 在解压后的 openssl-0.9.8g 目录下执行: perl Configure BC-32
二 生成批处理文件
在使用 configure 脚本配置好的编译参数后, 就可以使用批处理命令来生成编译脚本. 生成编译脚本根据采用编译器的不同通常使用不同的批处理文件. 就目前来说, 使用 vc 编译的时候有三种选择: do_ms,do_masm 和 do_nasm 来创建一系列编译脚本文件, 即. mak 脚本. 步骤如下:
vc: 在 openssl-1.0.1e 目录下, 执行命令来批处理文件: do_ms,do_masm 和 do_nasm
bc:1. 下载 nsm09839.zip 微软汇编编译器, 解压, 拷贝到 c:/windows 目录下, 修改名称为 nasmw.exe;2. 在 openssl-1.0.1e 目录下, 执行命令来批处理文件: ms\do_nasm
三 代码编译
vc:
完成上面步骤后, 可以看到两个关键脚本文件: nt.mak 和 ntdll.mak. 如果我们需要编译后的 OpenSSL 库是支持动态 DLL 形式的, 那么应该使用 ntddll.mak 文件进行编译, 这样编译完成我们会得到四个与 OpenSSL 的 API 库有关文件: ssleay32.lib,libeay32.lib,ssleay32.dll 和 libeay32.dll. 执行的编译命令形式如下: nmake -f ms\ntdll.mak
如果不希望以动态库的形式使用 OpenSSL, 那么可以使用 nt.mak 文件进行编译. 这样编译后使用 OpenSSL 的时候, 回直接将代码链接进我们的程序里面. 执行命令如下: nmake -f ms\nt.mak
bc: 执行命令来完成代码编译: make -f ms\bcb.mak
四 ELSE
测试动态库:
nmake -f ms\ntdll.mak test
测试静态库:
nmake -f ms\nt.mak test
安装动态库:
nmake -f ms\ntdll.mak install
安装静态库:
nmake -f ms\nt.mak install
清除上次动态库的编译,以便重新编译:
nmake -f ms\ntdll.mak clean
清除上次静态库的编译,以便重新编译:
nmake -f ms\nt.mak clean
- 使用 OpenSSL
在 VC 中配置使用以上的函数库:
点击菜单:Tools -> Options,弹出对话框 “Options”,在该对话框中选择 “Directories” 标签。
在 “Show directories for:” 的 “Include files” 选项中新增目录 “C:\openssl\include”;”Library files” 选择中新增目录 “C:\openssl\lib”。
然后在需要链接 OpenSSL 函数库的工程中编译时加入 “libeay32.lib” 就可以了。
全文完
本文由 简悦 SimpRead 优化,用以提升阅读体验。