libcurl使用起来不难,但编译对应的iOS库文件却是个大问题,编译过程中可能各种报错,网上找的库可能libcurl版本或者OpenSSL版本不符合要求,这时候就得自己找对应的OpenSSL和libcurl源码自己编译了。本文介绍的方案支持IPv6,混编openssl后可以支持https请求。
1.编译准备
我是从网络上找的脚本进行编译的,但是很多脚本都是不能用的,这个过程中浪费了很多时间,最后终于找到了可用的,GitHub链接如下:
https://github.com/sinofool/build-libcurl-ios
https://github.com/sinofool/build-openssl-ios
这两个链接里的脚本都下载下来,单独放到一个文件夹里面。
然后去openssl的官网https://www.openssl.org/source/和curl的官网https://curl.haxx.se/download.html
下载最新的源码,如下图
下载好了源码后也一起放入刚刚脚本所在的文件夹,并且把源码解压出来得到两个源码文件夹,最后该文件夹内容应该是如下图所示:
然后为了防止因为脚本没有权限而无法执行,我们需要赋予脚本可执行权限。也很简单,比如要赋予build_libcurl_dist.sh执行权限,我们打开终端,cd进入build_libcurl_dist.sh所在的文件夹,然后执行chmod 777 build_libcurl_dist.sh
就OK了。顺带也对build_openssl_dist.sh同样操作。
到这我们的准备工作就完成了。
2.开始编译
编译openssl
要支持https所以我们先得编译openssl,然后再把openssl库混编进libcurl中。
cd 进入我们上图中的openssl-1.1.0g源码文件夹,然后把build_openssl_dist.sh拖进终端,回车,就开始编译openssl了,编译完,你会发现桌面多了一个文件夹,里面放着openssl的库和.h文件,如下图:
编译libcurl
这时候,就该编译libcurl了,先cd进入curl-7.56.1源码文件夹,接着把build_libcurl_dist.sh脚本拖进终端,回车,等待编译完成,你会看到桌面上多了一个libcurl-ios-dist文件夹,里面就是我们最终得到的支持https、IPv6的库和.h文件了。注意下,刚刚那些openssl的.h也已经被混编入libcurl.a了,所以我们引用的时候不需要把openssl的那些文件拖进工程。
3.如何使用libcurl
使用说明就不多说了,很简单的,把编译得到的libcurl-ios-dist文件夹直接拖进工程,然后在工程里Targets的General 中,引用下libz.tbd这个系统库,使用curl的时候, #include "curl.h"就OK了。
如果想查看libcurl的版本号,printf("\nlibcurl verrsion %s\n",curl_version());
。打印结果是libcurl/7.56.1 SecureTransport
后面的 SecureTransport表示支持ssl,但是openssl的具体版本号目前我没找到对应的方法可以打印,下面这种方式打印出来的结果是openssl version SecureTransport
和上面一致,就是告诉你支持ssl但不告诉你版本号。
curl_version_info_data *data= curl_version_info(CURLVERSION_NOW);
printf("\nopenssl version %s\n",data->ssl_version);
这个data结构体有一个long ssl_version_num; /* not used, always zero */
这个属性,但官方文档告诉你,这属性用不了,只会返回0,我试过确实是只能返回0...不知道官方怎么想的。
具体如何用libcurl发起请求,请看我的另外一篇文章iOS用libcurl发起一个get请求,并保存返回数据到沙盒
4.尾声
简单概括就是,工欲善其事必先利其器,编译本身很简单,不过这个找对脚本就很折磨人了,网络上的其余脚本基本上都是不能编译最新的库的。希望给被困在这个问题上的同学们一点帮助。