一、使用 Libcurl 访问步骤:
1、调用curl_global_init()
初始化 libcurl
2、调用curl_easy_init()
函数得到 easy interface 型指针
3、调用curl_easy_setopt()
设置传输选项
4、根据curl_easy_setopt()
设置的传输选项,实现回调函数以完成用户特定任务
5、调用curl_easy_perform()
函数完成传输任务
6、调用curl_easy_cleanup()
释放内存
二、函数简介:
#include <curl/curl.h>
1、
CURLcode curl_global_init(long flags); // Libcurl 初始化
//参数 flags:
CURL_GLOBAL_ALL //初始化所有的可能的调用
CURL_GLOBAL_SSL //初始化支持安全套接字层
CURL_GLOBAL_WIN32 //初始化 win32 套接字库
CURL_GLOBAL_NOTHING //没有额外的初始化
注意!! 此函数只能调用一次(在调用curl_global_cleanup()
函数后可再次调用),如果这个函数在curl_easy_init()
函数调用时还没调用,它将由 libcurl 库自动调用,所以多线程下最好主动调用该函数以防止在线程中curl_easy_init()
时多次调用。curl_global_init()
是不能保证线程安全的,所以不要在每个线程中都调用curl_global_init()
,应该将curl_global_init()
函数的调用放在主线程中。
2、
CURL *curl_easy_init();
curl_easy_init()
用来初始化一个 CURL 的指针,相应的在调用结束时要用curl_easy_cleanup()
函数清理。一般curl_easy_init()
意味着一个会话的开始。它会返回一个easy_handle
(CURL*对象),一般都用在easy系列的函数中。
3、
CURLcode curl_easy_setopt(CURL *handle, CURLoption option, parameter);
// handle 参数:curl_easy_init 函数返回的句柄
// option 参数:
CURLOPT_URL //设置访问 URL,如:"http://www.baidu.com"
CURLOPT_WRITEFUNCTION /*函数将在 libcurl 接收到数据后被调用,因此函数多做数据保存的功能,如处理下载文件,即第三个参数
为一个函数*/
size_t function(