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 时需要使用到该程序。

    1. 下载最新版本的 Perl 然后安装之。
    2. 下载最新版本的 OpenSSL
    3. 然后将源码解压缩到某个目录(如 C:\openssl-0.9.8j)中。
    4. 进入 openssl 源码目录。
    5. cd c:\openssl-1.0.1e
    6. 以下为参照该目录下的文件 INSTALL.W32 的执行过程:
    7. 运行 configure
    8. perl Configure VC-WIN32
    9. 创建 Makefile 文件:
    10. ms\do_ms.bat
    11. 编译动态库:
    12. nmake -f ms\ntdll.mak
    13. 编译静态库:
    14. nmake -f ms\nt.mak
    15. 测试动态库:
    16. nmake -f ms\ntdll.mak test
    17. 测试静态库:
    18. nmake -f ms\nt.mak test
    19. 安装动态库:
    20. nmake -f ms\ntdll.mak install
    21. 安装静态库:
    22. nmake -f ms\nt.mak install
    23. 清除上次动态库的编译,以便重新编译:
    24. nmake -f ms\ntdll.mak clean
    25. 清除上次静态库的编译,以便重新编译:
    26. 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)

    1. 这是由于 OpenSSL 的静态函数库使用的是了 VC 的多线程 DLL Release 版本,而我的程序使用了多线程静态链接的 Release 版本。
    2. 调整 OpenSSL 的静态函数库使用的库函数版本即可,调整过程如下:
    3. 编辑文件 ms\nt.mak,将该文件第 19
    4. "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 编译的第一步, 这一步可以确定系统的环境, 使用什么编译器, 默认安装路径以及其他一些选项. 步骤如下:

    1. 安装 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

    1. 测试动态库:
    2. nmake -f ms\ntdll.mak test
    3. 测试静态库:
    4. nmake -f ms\nt.mak test
    5. 安装动态库:
    6. nmake -f ms\ntdll.mak install
    7. 安装静态库:
    8. nmake -f ms\nt.mak install
    9. 清除上次动态库的编译,以便重新编译:
    10. nmake -f ms\ntdll.mak clean
    11. 清除上次静态库的编译,以便重新编译:
    12. nmake -f ms\nt.mak clean
    1. 使用 OpenSSL
      在 VC 中配置使用以上的函数库:
      点击菜单:Tools -> Options,弹出对话框 “Options”,在该对话框中选择 “Directories” 标签。
      在 “Show directories for:” 的 “Include files” 选项中新增目录 “C:\openssl\include”;”Library files” 选择中新增目录 “C:\openssl\lib”。
      然后在需要链接 OpenSSL 函数库的工程中编译时加入 “libeay32.lib” 就可以了。
      全文完
      本文由 简悦 SimpRead 优化,用以提升阅读体验。