windows编译openssl+curl静态库

转载[有截图的一步步照做的编译老版本openssl1.0.2p,先看下](https://cloud.tencent.com/developer/article/1343632)

[较新的编译zlib/openssl/curl的方法](https://blog.csdn.net/lixiang987654321/article/details/81154613),这个blog里面步骤很清晰,基本照着做就行了,注意
在libcurl属性页,Librarian / General /additional dependencies, 添加libcrypto.lib, libssl.lib, zlib.lib 这个地方,在VS2019中是“文档管理程序”,而不是“链接库”

快速找到一些网站:
[perl下载地址](http://downloads.activestate.com/ActivePerl/releases/)
[nasm下载地址](https://www.nasm.us/pub/nasm/releasebuilds)
[zlib下载地址](http://www.zlib.net/)
[openssl下载地址](https://www.openssl.org/source/old/)
[curl for win下载地址](https://curl.haxx.se/download.html)

遇到的一些问题:
1.编译curl时提示“无法打开输入文件libeay32.lib”等可能是因为curl工程中一些项目属性没有设置正确。比如我用VS2019打开curl-all.sln解决方案查看项目属性时,发现工程中附加依赖项中写了依赖这个库,但我编译生成的是openssl1.1.1,库名称改了,哈哈。所以可能需要手动修改“文档管理程序——附加依赖项”中的库名称,【注意不同库名称用分号间隔】
2.“无法打开输入文件libcurl.lib”,还是通过检查库依赖、附加包含目录完成,注意,不只是libcurl的属性页要改,包括curl的属性页也要改哈。
3.“无法解析的外部符号 __imp__ioctlsocket”一大堆错误,可能缺少windows的一些默认库
4.“无法解析的外部符号 __imp__curl_”之类的跟curl相关的错误,是因为缺少设定的宏定义
5."无法解析的外部符号 __imp__CertOpenStore@20",等等,凡是跟crypt相关的,都是由于缺失Crypt32.lib

包括使用编译好的静态库时,也会有类似的错误
除了基础步骤,还有几个解决方案:
```
(1)给工程添加依赖库:项目->属性->链接器->输入->附加依赖项,ws2_32.lib;winmm.lib;wldap32.lib添加进去。有时候“文档管理程序——附加依赖项”这里改。注意要分号间隔
(2)检查“属性页——C/C++——预处理器——预处理器定义”中是否有定义BUILDING_LIBCURL;CURL_STATICLIB;这两个宏定义,当然也可以在引用处代码里面写#define BUILDING_LIBCURL 之类的。注意,有的blog里面还提到了HTTP_ONLY这个宏定义,这是没有编译openssl的时候才需要定义
(3)新版本openssl中需要用Crypt32.lib这个库,可以在属性页或头文件里面引用
```
我的项目里面是用QT的pro文件来构建解决方案,像windows的一些基础依赖库、宏定义和Crypt32.lib这个库的引用,在pro文件里面写都不好用。。。额

------------------------------------------------
附转载内容,防止丢失:【 注意,这里的命令基本都是在VS命令工具里面执行哈】
### 一、静态编译(openssl1.0.2o)
##### 1. 编译zlib
* (1)优先把找到Makefile.msc的CFLAGS  = -nologo -MD -W3 -O2 -Oy- -Zi -Fd"zlib" $(LOC)这一行,改为MD改为MT
* (2)使用VS2008 的 Command Prompt命令提示符工具(当然可以为任意你安装的开发环境命令行提示符工具)
* (3)cd到zlib的根目录,使用命令编译
```
nmake -f win32/Makefile.msc OBJA="inffast.obj"
```
扩展:编译64位
* (1)进入“Visual Studio 2015 x64 兼容工具命令提示”
* (2)在打开的vs 的x64环境命令中,进入zlib库,执行如下
 ```
contrib\masmx64\bld_ml64.bat
```
最终在zlib根目录生成对应头文件和lib静态库文件。

##### 2. 编译openssl
* (1)安装ActivePerl;
* (2)使用VS2008 的 Command Prompt命令提示符工具,cd到openssl的根目录,依次执行
* (3)执行如下命令
```
perl Configure VC-WIN32 no-asm 
```
这里说明:必须加no-asm,不然nmake报错:tmp32\sha1-586.asm(1427) : error A2070:invalid instruction operands
* (4)执行如下命令
 ```
ms\do_ms.bat 
```
此时在ms目录下会生成nt.mak文件
* (5)修改nt.make中的CFLAG 为 /MT,即静态库(动态为/MD)
* (6) 执行如下指令
```
make -f ms\nt.mak
```
最终生成的库文件生成在openssl根目录的out32下。

【如果要继续编译,或重新编译64位的,则先做如下清理】
```
nmake -f ms\nt.mak clean
 ```

64静态库编译步骤
           (1)执行perl Configure VC-WIN64A no-asm
           (2)执行ms\do_win64a.bat
           (3)修改ms\nt.mak编译选项为静态库MT(动态库MD)
            (4)执行nmake -f ms\nt.mak

输出在out32下面(为了区别32bit输出,请先将32bit编译out32更改为其他名称,然后在编译64位,最后将编出来的out32改为out64。
##### 3. 编译libcurl
* (1)zlib和openssl文件拷贝
进入libcurl目录,projects\Windows\VC9目录下新建一个文件夹例如:addfiles,并创建子目录:include,lib,并将zlib.h拷贝至include目录在include下新建子目录openssl, 将openssl.lib依赖的头文件全部拷贝至openssl目录下;将zlib.lib, ssleay32.lib, libeay32.lib拷贝到addfiles\lib目录下。
* (2)编译libcurl
进入libcurl的根目录,然后进入projects\Windows\VC9目录,直接用VS2008打开工程,在菜单栏选择LIB Release - LIB OpenSSL,Win32,在工程属性中设置如下:【在VS2019中是“文档管理程序”,而不是“链接库”】
```
在libcurl属性页,C/C++ / General /additional include Directories, 添加头文件目录..\addfiles\include
在libcurl属性页,Librarian / General /additional dependencies, 添加libeay32.lib, ssleay32.lib, zlib.lib
在libcurl属性页,Librarian / General /additional library Directories, 添加目录..\addfiles\lib
```
* (3)编译libcurl

编译完libcurl,最终libcurl库会生成到对应目录,win64类似
### 二、静态编译(openssl1.1.0h)
##### 1. 编译zlib
* (1)修改编译选项
优先把找到Makefile.msc的CFLAGS  = -nologo -MD -W3 -O2 -Oy- -Zi -Fd"zlib" $(LOC)这一行,改为MD改为MT
* (2)执行命令
使用VS2008 的 Command Prompt命令提示符工具,cd到zlib的根目录,使用命令编译
```
nmake -f win32/Makefile.msc OBJA="inffast.obj" 
```
##### 2. 编译openssl
* (1)安装ActivePerl;
* (2)静态编译
使用VS2008 的 Command Prompt命令提示符工具,cd到openssl的根目录,依次执行:
```
perl Configure VC-WIN32  shared no-asm no-shared --prefix="C:/openssl_lib/win32-release" --openssldir="C:/openssl_lib/win32-release/ssl" 
```
 注意:务必加入no-shared选项,表示只编译生成libcrypto.lib和libssl.lib,否则编译完成后的测试会失败。
* (3)开始编译测试和安装
```
编译:nmake
测试:nmake test(查验全部测试成功)
安装:nmake install(编译好的文件将会出现在win32-release中)
```
注意:(1)命令nmake clean可以清理清除编译Openssl-1.1.0f时产生的相关文件,不会清除C:/openssl-1.1.0f/win32-release目录下编译好的Openssl
 * (2)64位编译需要设置为perl Configure VC-WIN64A 或 perl Configure debug-VC-WIN64A

* (3)如果上一次编译完成,下一次编译需要清理上一次编译结果然后在重新编译,清理指令:nmake clean
##### 3. 编译libcurl
* (1)文件拷贝
projects\Windows\VC9目录下新建一个文件夹例如:addfiles,并创建子目录:include,lib,将zlib.h拷贝至include目录,在include下新建子目录openssl, 将openssl.lib依赖的头文件全部拷贝至openssl目录下,将zlib.lib, 添加libcrypto.lib, libssl.lib拷贝到addfiles\lib目录下。
* (2)编译
进入libcurl的根目录,然后进入projects\Windows\VC9目录,直接用VS2008打开工程,在菜单栏选择LIB Release - LIB OpenSSL,Win32,设置编译选项如下:
```
在libcurl属性页,C/C++ / General /additional include Directories, 添加头文件目录..\addfiles\include
在libcurl属性页,Librarian / General /additional dependencies, 添加libcrypto.lib, libssl.lib, zlib.lib
在libcurl属性页,Librarian / General /additional library Directories, 添加目录..\addfiles\lib
```
最后编译生成libcurl静态库即可。

##### 4、重点问题注意

(1)项目中调用openssl时,必须添加一个密码学库:crypt32;
```
#pragma comment (lib, "crypt32")
```
原因:openssl库使用了windows的一个密码学库: crypt32。否则报错

1>libcrypto.lib(e_capi.obj) : error LNK2001: 无法解析的外部符号 __imp__CertFreeCertificateContext@4  
1>libcrypto.lib(e_capi.obj) : error LNK2001: 无法解析的外部符号 __imp__CertGetCertificateContextProperty@16  
1>libcrypto.lib(e_capi.obj) : error LNK2001: 无法解析的外部符号 __imp__CertOpenStore@20  
1>libcrypto.lib(e_capi.obj) : error LNK2001: 无法解析的外部符号 __imp__CertFindCertificateInStore@24  
1>libcrypto.lib(e_capi.obj) : error LNK2001: 无法解析的外部符号 __imp__CertEnumCertificatesInStore@8  
1>libcrypto.lib(e_capi.obj) : error LNK2001: 无法解析的外部符号 __imp__CertCloseStore@8  
1>libcrypto.lib(e_capi.obj) : error LNK2001: 无法解析的外部符号 __imp__CertDuplicateCertificateContext@4  
1>D:\code\opensslbaseapp\Release\PosCipherTest.exe : fatal error LNK1120: 7 个无法解析的外部命令  
1>  
 
 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值