前提概要
众所周知,http/https是当下开发应用程序时,网路部分不可或缺的部分,我们可以基于socket自己来实现,因为http/https本身是基于TCP实现的应用层协议(位于网络模型的第7层)。但随着行业的发展,https加密、业内非标准http协议的推广(CDN非标准协议)等这些部分,都需要耗费大量的开发成本,基于socket自己实现http/https的方案,成本上已经难以接受,选择开源的成熟方案是当下业内的共识。而curl是http/https最成熟的开源方案,其兼顾稳定性和易用性、跨平台性,是作为底层库的首选。当然其他一体化底层解决方案也是不错的选择,例如Mars(微信开源框架),Qt等,这里我们仅在单一http/https方案这一选择中来做探讨。
curl虽然易于使用,但在各平台编译上,有不少晦涩难懂的地方,也是它对于使用者来说最大的障碍,这篇文章旨在消除这些障碍,拨开云雾,一站式解决各平台编译问题,从而将大家宝贵的精力从中抽出,用在更有价值的事情上。
参考资料:
https://curl.haxx.se/docs/install.html
http://p-nand-q.com/programming/windows/building_openssl_with_visual_studio_2013.html
https://wiki.openssl.org/index.php/Main_Page
基本脉络
这里是我个人理解下来,需要大家提前搞懂的几个点,整理出脉络图,以便理解。和代码阅读类似,我们先观其行,然后再达其意,有利于各个击破,如果能接触到一两个有意思的技术历史,那也不失为过程中的风景,本篇文章也会按照各平台来逐一介绍和阐述。
整体工程
请务必下载下来如下链接中整体curl编译工程,然后再针对性阅读后续介绍
百度云盘:https://pan.baidu.com/s/1yXdqiUMBiHqeyVktlFUQ9A
腾讯微云:https://share.weiyun.com/5t9cdnJ
针对整体工程,我们分如下几部分做介绍:
1.mac/ios编译
2.windows编译
3.android编译
4.openssl多线程安全
工程目录结构如下:
一、Mac编译
主要参考curl官方文档:
https://curl.haxx.se/docs/install.html
iOS的编译,这里我稍作说明,由于个人精力的缘故,没有完整实践过,之前看官方文档的时候,大致看到方法应该是类似的,由于移动平台CPU多种多样,这里是否有编译上的差异,我还未做考证。总之,再麻烦总不会麻烦过Android(文章后半段大家会感觉到这一点),请大家阅读好官方文档,我们要做的大多数情况下只是保持好正确的坐姿,设置好编译参数,然后正确调用编译命令。
注意事项
需要更新到xcode9.4.1以上版本,curl-7.63.0版本在xcode9.2.1版本编译会报如下错误:
Undefined symbols for architecture x86_64:
“_SSLCopyALPNProtocols”, referenced from:
_darwinssl_connect_step2 in libcurl.a(libcurl_la-darwinssl.o)
“_SSLSetALPNProtocols”, referenced from:
_darwinssl_connect_common in libcurl.a(libcurl_la-darwinssl.o)
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)
make[2]:[curl] Error 1
make[1]:[install-recursive] Error 1
make: [install-recursive] Error 1
编译脚本build/libcurl/build_for_mac.sh执行的步骤:
1.解压源码:curl-7.63.0.tar.gz
2.编译libcurl
关键代码(限于篇幅只贴出部分脚本):其中current_path是当前脚本执行路径,是编译输出路径,也可以配置为自定义的输出路径
export MACOSX_DEPLOYMENT_TARGET=“10.6”
# buid configure
./buildconf
./configure --prefix=$current_path/out
--disable-shared
--enable-static
--with-darwinssl
--enable-threaded-resolver
--disable-ldap
--disable-ldaps
# workaround still works though: make CFLAGS=-Wno-error for buid bug before v7.55.1
# the build error is:connectx’ is only available on macOS 10.11 or newer
#make CFLAGS=-Wno-error
make
# install
make install</