libcurl中curl_easy_setopt()和curl_easy_perform()函数使用中文详解

原:http://blog.sina.com.cn/s/blog_7e0127220100zfbf.html

libcurl里主要用到的函数有curl_easy_init(),curl_easy_setopt()和curl_easy_perform().

顾名思义,curl_easy_init()是用来初始化libcurl库的(不知道对不对,就这么理解吧),
curl_easy_setopt()是用来设置各种curl参数的,setopt就是set option,
curl_easy_perform()是用来执行curl的各种操作的,并且通过分析其返回值,可以判断curl执行的情况。
1)curl_easy_setopt函数介绍

本节主要介绍curl_easy_setopt中跟http相关的参数。注意本节的阐述都是以libcurl作为主体,其它为客体来阐述的。
1.CURLOPT_URL
设置访问URL
2.CURLOPT_WRITEFUNCTION,CURLOPT_WRITEDATA
通过设定一个回调函数,执行libcurl在接受到数据后用户想进行的操作,通常函数多做数据保存的功能,如处理下载文件。CURLOPT_WRITEDATA 用于表明CURLOPT_WRITEFUNCTION函数中的stream指针的来源,说白了就是设定回调函数的第四个参数的数据类型。回调函数原型为:size_t function( void *ptr, size_t size, size_t nmemb, void *stream);
3.CURLOPT_HEADERFUNCTION,CURLOPT_HEADERDATA
通过设定一个回调函数,执行libcurl在接受到http头数据后用户想进行的操作。CURLOPT_WRITEDATA 传递指针给libcurl,该指针表明CURLOPT_HEADERFUNCTION 函数的stream指针的来源。回调函数原型为 size_t function( void *ptr, size_t size,size_t nmemb, void *stream);
4.CURLOPT_READFUNCTION CURLOPT_READDATA
libCurl需要读取数据传递给远程主机时将调用CURLOPT_READFUNCTION指定的函数,函数原型是:size_t function(void *ptr, size_t size, size_t nmemb,void *stream). CURLOPT_READDATA 表明CURLOPT_READFUNCTION函数原型中的stream指针来源,说白了就是设定回调函数的第四个参数的数据类型。
5.CURLOPT_NOPROGRESS,CURLOPT_PROGRESSFUNCTION,CURLOPT_PROGRESSDATA
跟数据传输进度相关的参数。CURLOPT_PROGRESSFUNCTION 指定的函数正常情况下每秒被libcurl调用一次,为了使CURLOPT_PROGRESSFUNCTION被调 用,CURLOPT_NOPROGRESS必须被设置为false,CURLOPT_PROGRESSDATA指定的参数将作为 CURLOPT_PROGRESSFUNCTION指定函数的第一个参数
6.CURLOPT_TIMEOUT,CURLOPT_CONNECTIONTIMEOUT:
CURLOPT_TIMEOUT 用于设置传输时间,CURLOPT_CONNECTIONTIMEOUT 设置连接等待时间
7.CURLOPT_FOLLOWLOCATION
设置重定位URL
CURLOPT_RANGE: CURLOPT_RESUME_FROM:
断点续传相关设置。CURLOPT_RANGE 指定char *参数传递给libcurl,用于指明http域的RANGE头域,例如:
表示头500个字节:bytes=0-499
表示第二个500字节:bytes=500-999
表示最后500个字节:bytes=-500
表示500字节以后的范围:bytes=500-
第一个和最后一个字节:bytes=0-0,-1
同时指定几个范围:bytes=500-600,601-999
    CURLOPT_RESUME_FROM 传递一个long参数给libcurl,指定你希望开始传递的偏移量。
8.CURLOPT_UPLOAD:
如果第三个参数被设置为1的话,就是让libcurl做好上传的准备。如果传输协议是http的话,uoload就是发送put。
9. CURLOPT_SSL_VERIFYPEER:
第三个参数的缺省值为1.该函数多用于设定curl忽略对网站证书的检查(不管忽略不忽略,curl都是检查的)。
10.CURLOPT_VERBOSE
相当厉害的一个参数,可以向控制台(默认)输出curl接受和发送的数据,输出流可以重定向。
11.CURLOPT_HTTPGET
将curl向服务器交互数据的方式改变为get

2)curl_easy_perform 函数说明(error 状态码)

该函数完成curl_easy_setopt指定的所有选项,本节重点介绍curl_easy_perform的返回值。返回0意味一切ok,非0代表错误发生。主要错误码说明:
1.CURLE_OK
任务完成一切都好
2.CURLE_UNSUPPORTED_PROTOCOL
不支持的协议,由URL的头部指定
3.CURLE_COULDNT_CONNECT
不能连接到remote 主机或者代理
4.CURLE_REMOTE_ACCESS_DENIED
访问被拒绝
5.CURLE_HTTP_RETURNED_ERROR
Http返回错误
6.CURLE_READ_ERROR
读本地文件错误

3)curl_easy_getinfo函数说明

1.CURLINFO_RESPONSE_CODE
获得http返回的状态码,如400,200

### 回答1: 可以通过使用curl_easy_setopt函数来设置输出处理函数,具体的语法为:curl_easy_setopt(handle, CURLOPT_WRITEFUNCTION, write_data); 其中 write_data 是输出处理函数的名称。 ### 回答2: 在使用cURL库中的curl_easy_setopt函数时,可以通过设置输出处理函数来处理cURL执行操作的输出。设置输出处理函数的步骤如下: 1. 创建一个用于处理输出的函数。 这个函数的格式必须符合以下原型: size_t handle_output(void *ptr, size_t size, size_t nmemb, void *userdata); 函数的参数依次为ptr,size,nmembuserdata。其中,ptr是接收到的数据指针,size是每个数据项的大小,nmemb是接收到的数据项数目,userdata是一个用户指定的指针,可用于传递自定义数据。 2. 在代码中定义代表cURL会话的CURL类型的变量,并通过curl_easy_init函数进行初始化。 3. 调用curl_easy_setopt函数,并将设置项设为CURLOPT_WRITEFUNCTION,第二个参数为输出处理函数的指针。 4. 如果需要传递自定义数据给输出处理函数,则还可以使用curl_easy_setopt函数设置CURLOPT_WRITEDATA选项,第二个参数为自定义数据的指针。 5. 执行需要的cURL操作,如发送HTTP请求。 下面是一个简单的示例代码,演示如何设置输出处理函数: ```c #include <stdio.h> #include <curl/curl.h> size_t handle_output(void *ptr, size_t size, size_t nmemb, void *userdata) { // 处理接收到的数据 // ptr是接收到的数据指针,size是每个数据项的大小,nmemb是接收到的数据项数目,userdata是自定义数据指针 // 示例代码中,直接打印接收到的数据到控制台 size_t total_size = size * nmemb; fwrite(ptr, 1, total_size, stdout); return total_size; } int main() { CURL *curl; curl = curl_easy_init(); if (curl) { curl_easy_setopt(curl, CURLOPT_URL, "http://www.example.com"); // 设置请求的URL curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, handle_output); // 设置输出处理函数 // 可选:设置自定义数据指针 // curl_easy_setopt(curl, CURLOPT_WRITEDATA, custom_data_ptr); CURLcode res = curl_easy_perform(curl); // 执行请求操作 if (res != CURLE_OK) { fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res)); } curl_easy_cleanup(curl); } return 0; } ``` 以上是设置curl_easy_setopt的输出处理函数的简要步骤示例代码。根据需要,可以在输出处理函数中自定义处理接收到的数据。 ### 回答3: curl_easy_setopt函数libcurl库中用于设置选项的函数,可以通过该函数设置curl的各种行为选项。其中一个常见的选项是设置输出处理函数,即设置curl用于处理响应数据的回调函数。 要设置curl的输出处理函数,需要使用curl_easy_setopt函数,并将选项参数设置为CURLOPT_WRITEFUNCTION,然后将回调函数作为参数传递给该选项。 具体的代码如下所示: ``` // 声明输出处理函数,需要符合curl_write_callback类型的定义 size_t writeCallback(char* ptr, size_t size, size_t nmemb, void* userdata) { // 在这里对收到的数据进行处理 // ptr:收到的数据指针 // size:每个数据元素的大小 // nmemb:数据元素的数量 // userdata:用户自定义数据指针 // 返回值表示实际处理的字节数 } // 初始化curl CURL* curl = curl_easy_init(); if(curl) { // 设置输出处理函数 curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, writeCallback); // 这里可以继续设置其他选项... // 执行curl请求 CURLcode res = curl_easy_perform(curl); if(res != CURLE_OK) { // 请求失败的处理逻辑... } // 清理curl curl_easy_cleanup(curl); } ``` 在上述代码中,通过curl_easy_setopt函数将选项参数设置为CURLOPT_WRITEFUNCTION,并将回调函数writeCallback作为参数传递。在writeCallback回调函数中,可以对收到的响应数据进行处理。在函数内部,可以通过参数ptr、sizenmemb访问到接收到的数据。需要注意,writeCallback回调函数的返回值需要表示实际处理的字节数。 通过这种方式,我们可以自定义输出处理函数来处理curl接收到的响应数据,实现自己的数据处理逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值