tutorial opt easy descargar c libcurl

opt - C libcurl obtiene salida en una cadena



libcurl easy opt (3)

Quiero almacenar el resultado de esta función curl en una variable, ¿cómo puedo hacerlo?

#include <stdio.h> #include <curl/curl.h> int main(void) { CURL *curl; CURLcode res; curl = curl_easy_init(); if(curl) { curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se"); res = curl_easy_perform(curl); /* always cleanup */ curl_easy_cleanup(curl); } return 0; }

gracias, lo solucioné así:

#include <stdio.h> #include <stdlib.h> #include <curl/curl.h> function_pt(void *ptr, size_t size, size_t nmemb, void *stream){ printf("%d", atoi(ptr)); } int main(void) { CURL *curl; curl = curl_easy_init(); if(curl) { curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se"); curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, function_pt); curl_easy_perform(curl); curl_easy_cleanup(curl); } system("pause"); return 0; }


La siguiente respuesta es la forma C ++ de hacerlo, con std::string , en lugar de cadena terminada en nulo. Todavía usa una función de devolución de llamada (no hay forma de evitarlo), pero también maneja el error de asignación usando try / catch.

#include <iostream> #include <string> #include <curl/curl.h> size_t CurlWrite_CallbackFunc_StdString(void *contents, size_t size, size_t nmemb, std::string *s) { size_t newLength = size*nmemb; size_t oldLength = s->size(); try { s->resize(oldLength + newLength); } catch(std::bad_alloc &e) { //handle memory problem return 0; } std::copy((char*)contents,(char*)contents+newLength,s->begin()+oldLength); return size*nmemb; } int main() { CURL *curl; CURLcode res; curl_global_init(CURL_GLOBAL_DEFAULT); curl = curl_easy_init(); std::string s; if(curl) { curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se"); curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L); //only for https curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L); //only for https curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, CurlWrite_CallbackFunc_StdString); curl_easy_setopt(curl, CURLOPT_WRITEDATA, &s); curl_easy_setopt (curl, CURLOPT_VERBOSE, 1L); //remove this to disable verbose output /* Perform the request, res will get the return code */ res = curl_easy_perform(curl); /* Check for errors */ if(res != CURLE_OK) { fprintf(stderr, "curl_easy_perform() failed: %s/n", curl_easy_strerror(res)); } /* always cleanup */ curl_easy_cleanup(curl); } std::cout<<s<<std::endl; std::cout<< "Program finished!" << std::endl; }


Lea el manual aquí: http://curl.haxx.se/libcurl/c/curl_easy_setopt.html Creo que necesita varias llamadas a CURL_SETOPT, la primera es la URL que desea procesar, la segunda es algo así como:

curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, function_ptr);

Donde function_ptr coincide con esta firma:

size_t function( void *ptr, size_t size, size_t nmemb, void *stream)

Lo que sucede aquí es que denotan una función de devolución de llamada a la que libcurl llamará cuando tenga alguna salida para escribir desde cualquier transferencia que haya invocado. Puede hacer que escriba automáticamente en un archivo, o pasarle un puntero a una función que manejará la salida en sí. Usando esta función, debería ser capaz de ensamblar varias cadenas de salida en una sola pieza y luego usarlas en su programa.

No estoy seguro de qué otras opciones puede tener que configurar / qué más afecta la forma en que desea que se comporte su aplicación, así que eche un vistazo a esa página.


Puede configurar una función de devolución de llamada para recibir fragmentos de datos entrantes usando curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, myfunc);

La devolución de llamada tendrá un argumento definido por el usuario que puede establecer utilizando curl_easy_setopt(curl, CURLOPT_WRITEDATA, p)

Aquí hay un fragmento de código que pasa una struct string {*ptr; len} almacenamiento intermedio struct string {*ptr; len} struct string {*ptr; len} a la función de devolución de llamada y crece ese búfer en cada llamada con realloc ().

#include <stdio.h> #include <stdlib.h> #include <string.h> #include <curl/curl.h> struct string { char *ptr; size_t len; }; void init_string(struct string *s) { s->len = 0; s->ptr = malloc(s->len+1); if (s->ptr == NULL) { fprintf(stderr, "malloc() failed/n"); exit(EXIT_FAILURE); } s->ptr[0] = ''/0''; } size_t writefunc(void *ptr, size_t size, size_t nmemb, struct string *s) { size_t new_len = s->len + size*nmemb; s->ptr = realloc(s->ptr, new_len+1); if (s->ptr == NULL) { fprintf(stderr, "realloc() failed/n"); exit(EXIT_FAILURE); } memcpy(s->ptr+s->len, ptr, size*nmemb); s->ptr[new_len] = ''/0''; s->len = new_len; return size*nmemb; } int main(void) { CURL *curl; CURLcode res; curl = curl_easy_init(); if(curl) { struct string s; init_string(&s); curl_easy_setopt(curl, CURLOPT_URL, "curl.haxx.se"); curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, writefunc); curl_easy_setopt(curl, CURLOPT_WRITEDATA, &s); res = curl_easy_perform(curl); printf("%s/n", s.ptr); free(s.ptr); /* always cleanup */ curl_easy_cleanup(curl); } return 0; }