curl返回值写入内存的场景

直接上代码:

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <string.h>
 4 #include <curl/curl.h>
 5
 6 struct MemoryStruct {
 7   char *memory;
 8   size_t size;
 9 };
10
11 static size_t
12 WriteMemoryCallback(void *contents, size_t size, size_t nmemb, void *userp)
13 {
14   size_t realsize = size * nmemb;
15   struct MemoryStruct *mem = (struct MemoryStruct *)userp;
16
17   mem->memory = (char*)realloc(mem->memory, mem->size + realsize + 1);
18   if(mem->memory == NULL) {
19     /* out of memory! */
20     printf("not enough memory (realloc returned NULL)\n");
21     return 0;
22   }
23
24   memcpy(&(mem->memory[mem->size]), contents, realsize);
25   mem->size += realsize;
26   mem->memory[mem->size] = 0;
27
28   return realsize;
29 }
30 int main(void)
31 {
32   CURL *curl;
33   CURLcode res;
34   struct MemoryStruct chunk;
35   static const char *postthis="Field=1&Field=2&Field=3";
36
37   chunk.memory = (char*)malloc(1);  /* will be grown as needed by realloc above */
38   chunk.size = 0;    /* no data at this point */
39
40   curl_global_init(CURL_GLOBAL_ALL);
41   curl = curl_easy_init();
42   if(curl) {
43
44     curl_easy_setopt(curl, CURLOPT_URL, "http://www.example.org/");
45
46     /* send all data to this function  */
47     curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
48
49     /* we pass our 'chunk' struct to the callback function */
50     curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk);
51
52     /* some servers don't like requests that are made without a user-agent
53        field, so we provide one */
54     curl_easy_setopt(curl, CURLOPT_USERAGENT, "libcurl-agent/1.0");
55
56     curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postthis);
57
58     /* if we don't provide POSTFIELDSIZE, libcurl will strlen() by
59        itself */
60     curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, (long)strlen(postthis));
61
62     /* Perform the request, res will get the return code */
63     res = curl_easy_perform(curl);
64     /* Check for errors */
65     if(res != CURLE_OK) {
66       fprintf(stderr, "curl_easy_perform() failed: %s\n",
67               curl_easy_strerror(res));
68     }
69     else {
70       /*
71        * Now, our chunk.memory points to a memory block that is chunk.size
72        * bytes big and contains the remote file.
73        *
74        * Do something nice with it!
75        */
76       printf("%s\n",chunk.memory);
77     }
78
79     /* always cleanup */
80     curl_easy_cleanup(curl);
81
82     free(chunk.memory);
83
84     /* we're done with libcurl, so clean it up */
85     curl_global_cleanup();
86   }
87   return 0;
88 }

 

时间: 2024-10-26 22:02:50

curl返回值写入内存的场景的相关文章

ajax-Ajax返回值写入HTML里?

问题描述 Ajax返回值写入HTML里? 两个页面:后端php随机生成一堆字符串,前端定时器+Ajax获取后端字符串. 问题:现在能获取到字符串,想要实现responseText过来的字符串输出到HTML里,右键源文件可看见的形式,因为下一步sc.get([ ])里需要调用这串字符串来给客户端显示样式.? innerHTML只能写入到DOM里,可sc.get([ ])是js语句里的,无法满足要求. document.write()试过,不更新数据. 解决方案 function showTime(

基于C++内存分配、函数调用与返回值的深入分析_C 语言

在谈述函数调用和返回值问题之前,先来看看C++中内存分配的问题. C++编译器将计算机内存分为代码区和数据区,很显然,代码区就是存放程序代码,而数据区则是存放程序编译和执行过程出现的变量和常量.数据区又分为静态数据区.动态数据区,动态数据区包括堆区和栈区.以下是各个区的作用:(1)代码区:存放程序代码:(2)数据区a.静态数据区: 在编译器进行编译的时候就为该变量分配的内存,存放在这个区的数据在程序全部执行结束后系统自动释放,生命周期贯穿于整个程序执行过程.b.动态数据区:包括堆区和栈区堆区:这

C++中内存分配、函数调用和返回值问题(1/2)

在谈述函数调用和返回值问题之前,先来看看c++中内存分配的问题. c++编译器将计算机内存分为代码区和数据区,很显然,代码区就是存放程序代码,而数据区则是存放程序编译和执行过程出现的变量和常量.数据区又分为静态数据区.动态数据区以及常量区,动态数据区包括堆区和栈区. 一下是各个区的作用: (1)代码区:存放程序代码: (2)数据区    a.静态数据区: 在编译器进行编译的时候就为该变量分配的内存,即全局变量和静态变量(用static声明的变量),存放在这个区的数据程序全部执行结束后系统自动释放

PHP CURL获取返回值的方法

  这篇文章主要介绍了PHP CURL获取返回值的方法,需要的朋友可以参考下 在CURL中有一个参数 CURLOPT_RETURNTRANSFER : 代码如下:curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0); 默认是 0 直接返回获取的输出的文本流,有时候,我们要拿返回值来做判断或者做其他用途的话那就不太好了. 幸好CURLOPT_RETURNTRANSFER 可以设置,如果设置成CURLOPT_RETURNTRANSFER 1: 代码如下:curl_s

PHP 中用curl访问一个页面和直接在浏览器中直接访问这个页面为什么两次的返回值不一样?

问题描述 PHP 中用curl访问一个页面和直接在浏览器中直接访问这个页面为什么两次的返回值不一样? 直接在浏览器中访问 用PHP中的curl访问后,为甚么两次的不一样?? 解决方案 你用curl访问时的参数设置跟你用浏览器时的设置是否一样?明显示这里不能使用匿名访问 解决方案二: useragent和header看下是否一样的. 字面意思是说匿名访问,是否要模拟登陆啊,推荐用chrome或者firefox的调试模式看下这几个信息是否有什么特别需要设置的

谨防数组函数返回值造成的内存泄露

数组作为函数返回值时,非常容易引起内存泄露. 问题现象:Build应用程序后,提示非法内存访问:可是Compile应用程序却没有这个问题. 问题思考:函数返回值,在被调用函数中负责释放:局部变量也是在函数调用结束后在函数内被释放.如果一个函数调用了另外一个函数,却没有使用被调用函数的返回值,就有可能造成内存泄露.   //数组作为函数返回值 function StrToPByte(Const str: string;Var arrByte: array of byte): PByte;var 

PHP CURL获取返回值的方法_php技巧

在CURL中有一个参数 CURLOPT_RETURNTRANSFER : 复制代码 代码如下: curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0); 默认是 0 直接返回获取的输出的文本流,有时候,我们要拿返回值来做判断或者做其他用途的话那就不太好了. 幸好CURLOPT_RETURNTRANSFER  可以设置,如果设置成CURLOPT_RETURNTRANSFER 1: 复制代码 代码如下: curl_setopt($ch, CURLOPT_RETURNT

异常和返回值的使用场景。

问题描述 请教一下,在java.io.Inputstream中,read()校验是抛出RuntimeException,而skip()的校验是return0呢?publicintread(byteb[],intoff,intlen)throwsIOException{if(b==null){thrownewNullPointerException();}elseif(off<0||len<0||len>b.length-off){thrownewIndexOutOfBoundsExcep

Linux system函数返回值

例: [cpp] view plain copy   status = system("./test.sh");   1.先统一两个说法: (1)system返回值:指调用system函数后的返回值,比如上例中status为system返回值 (2)shell返回值:指system所调用的shell命令的返回值,比如上例中,test.sh中返回的值为shell返回值.   2.如何正确判断test.sh是否正确执行? 仅判断status是否==0?或者仅判断status是否!=-1?