我正在使用 libcurl 执行 HTTP 请求并响应我的网页。但是当得到响应时,我没有得到完整的服务器响应。响应线在某一点被截断。例如
10-25 15:53:22.264: XXX(14847): Security.8021x:true
10-25 15:53:22.264: XXX(14847): Event.AlarmInput:true
10-25 15:53:22.264: XXX(14847): Event.AlarmInput.Notification.HTTP.CGI:true
10-25 15:53:22.264: XXX(14847): Event.AlarmInput.Notification.HTTP.CGI.SingleSession:true
10-25 15:53:22.264: XXX(14847): Event.AlarmInpu .............
注意:这是一个自定义的 android 日志。请不要与输出线混淆
响应中还有大约 10 行,但我当前的日志显示在“Event.AlarmInpu”之后没有输出。
当我给出 curl 命令行选项时
curl http://www.google.com > output.txt
我可以在文件中找到完整的输出行。
当我使用 curl 命令行工具并将响应移动到输出文件时,我可以看到整个响应数据。所以我可以同意 curl 命令正在正确检索整个响应。我得到了整个响应,但是响应比我的缓冲区长度长,因此它被截断了。
请让我知道如何增加缓冲区长度以获得完整的响应行。
代码片段如下所示
typedef struct pageInfo_t {
char *data;
int len;
} pageInfo_t;
static size_t HTTPData(void *buffer, size_t size, size_t nmemb, void *userData)
{
int len = size * nmemb;
pageInfo_t *page = (pageInfo_t *)userData;
page->data = realloc(page->data,page->len + len +1);
memcpy(&page->data[page->len], buffer, len);
page->len += len;
page->data[page->len] = 0;
return len;
}
//Inteface funciton that will recieve web page fom Java
jstring Java_com_samsung_jnitest_MainActivity_JNIGetWebpage( JNIEnv* env,jobject entryObject,jstring webpageJStr)
{
pageInfo_t page;
CURL *curl;
CURLcode res;
char *buffer;
int memorysize = 19189;
page.data = (char *)malloc(16 * memorysize);
page.len = 0;
if (page.data)
memset(page.data, 32, 16 * memorysize);
buffer = (char *)malloc(memorysize);
curl = curl_easy_init();
if(curl)
{
curl_easy_setopt(curl, CURLOPT_URL, webpage);
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, HTTPData);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &page);
res = curl_easy_perform(curl);
curl_easy_cleanup(curl);
(*env)->ReleaseStringUTFChars(env, webpageJStr, webpage);
if(response_code == 200)
{
if (buffer)
{
page.data[page.len] = '\0';
sprintf(buffer, "%ld:%s \n", response_code, page.data);
return (*env)->NewStringUTF(env, buffer);
}
}
}
}
请让我知道如何增加缓冲区大小以保存完整的响应行。
让我知道我是否过度复杂化代码