近来必要用curl来发送http哀求,遇到了不少问题,查了不少资料,都是零零散散的,现在总结下。
1、移植编译
1 ./configure --prefix=$(PWD)/build --host=arm-XXX-linux;make ;make install
这步基本都没有问题,天生的动态链接库libcurl.a,可以直接给应用步伐去使用。
2、API使用
1)全局初始化 curl_global_init(CURL_GLOBAL_ALL);
2)通过curl_easy_init得到一个CURL指针m_pCurl
3)通过curl_formadd封装参数
通过curl_easy_setopt设置各种选项
通过curl_easy_perform实行curl的各种操作
4)curl_easy_getinfo 得到http返回的状态码
5)curl_easy_cleanup开释CURL指针
6)curl_global_cleanup开释全局对象
3、http的相应内容获取
先通过 curl_easy_setopt设置CURLOPT_WRITEFUNCTION,CURLOPT_WRITEDATA选项
- size_t ReviceData(char *buffer, size_t size, size_t nmemb, std::stringstream & stream)
- {
- size_t total = size * nmemb;
- std::string str = "";
- if (total)
- {
- str.append(buffer, total);
- }
- stream << str.c_str();
- return total;
- }
- std::stringstream out;
- curl_easy_setopt(m_pCurl, CURLOPT_WRITEFUNCTION, ReviceData);
- curl_easy_setopt(m_pCurl, CURLOPT_WRITEDATA, &out);
复制代码
当有相应返来的时间,会触发ReviceData函数,在这个回调函数,会把相应的内容,赋值给out变量,如许相应就取得了。
4、遇到的一些问题
curl_easy_setopt(m_pCurl, CURLOPT_CONNECTTIMEOUT, 4L); curl_easy_setopt(m_pCurl, CURLOPT_TIMEOUT, 25L);
设置了超时时间后(一个是等候连接的时间,一个是等候吸收相应的时间)一旦域名解析失败,步伐会莫名的挂掉,而且每次挂掉的地方都不一样。当时也是通过一点一点表明代码,才定位到这两行代码。
coredump的原因是因为curl的DNS解析超时控制是使用SIGALARM实现的。
如许导致发现SIGALARM会出现多线程修改同一个全局变量,由此产生了COREDUMP。
问题发生的条件是设置了CURLOPT_TIMEOUT或CURLOPT_CONNECTTIMEOUT,并且值不为0。
办理办法:
1) 设置CURLOPT_NOSIGNAL的值为1
curl_easy_setopt(m_pCurl, CURLOPT_NOSIGNAL, 1);
设置之后,发现简直不会coredump了,但是设置的超时时间没有用了,必要等好久,才气出效果。
2) 使用c-ares(configure时指定参数--enable-ares)
使用这个方法比力好,不会coredump,而且超时时间设置后收效。
下面先容下这个方法:
a、下载cares的源码,进行编译移植
https://c-ares.haxx.se/
编译方法和curl的编译方法类似,都是通过configure ,终极天生libcares.a
b、修改curl源码里的configure文件
找到下面的代码,添加embedded_ares="yes",箭头所指的地方,不然check
的时间,会报c-ares library defective or too old
c、重新编译curl
- ./configure --enable-ares=$(PWD)/depends --prefix=$(PWD)/build --host=arm-XXX-linux;make ;make install
复制代码
这里指定了enable-ares使用的libares所在的目次。depends目次下必要再建立一个子目次lib,在子目次下放入libcares.a即可。
还要把libcares的头文件都拷贝到curl主目次里的lib目次里,如许编译就不会堕落了。
来源:https://www.cnblogs.com/ahcc08/p/11656395.html |