Вам придется использовать CURLOPT_WRITEFUNCTION
, чтобы установить обратный вызов для записи. Я не могу проверить, чтобы скомпилировать это прямо сейчас, но функция должна выглядеть примерно так:
static std::string readBuffer;
static size_t WriteCallback(void *contents, size_t size, size_t nmemb, void *userp)
{
size_t realsize = size * nmemb;
readBuffer.append(contents, realsize);
return realsize;
}
Тогда назовите это, делая;
readBuffer.clear();
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteCallback);
// ...other curl options
res = curl_easy_perform(curl);
После звонка readBuffer
должен иметь ваше содержимое.
Редактировать: вы можете использовать CURLOPT_WRITEDATA
для передачи строки буфера вместо того, чтобы делать ее статической. В этом случае я просто сделал это статичным для простоты. Хорошая страница для просмотра (помимо приведенного выше связанного примера) - здесь для объяснения параметров.
Edit2: по запросу, вот полный рабочий пример без статического строкового буфера;
#include <iostream>
#include <string>
#include <curl/curl.h>
static size_t WriteCallback(void *contents, size_t size, size_t nmemb, void *userp)
{
((std::string*)userp)->append((char*)contents, size * nmemb);
return size * nmemb;
}
int main(void)
{
CURL *curl;
CURLcode res;
std::string readBuffer;
curl = curl_easy_init();
if(curl) {
curl_easy_setopt(curl, CURLOPT_URL, "http://www.google.com");
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteCallback);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &readBuffer);
res = curl_easy_perform(curl);
curl_easy_cleanup(curl);
std::cout << readBuffer << std::endl;
}
return 0;
}