1

我正在使用 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);
            }
        }
    }
} 

请让我知道如何增加缓冲区大小以保存完整的响应行。
让我知道我是否过度复杂化代码

4

2 回答 2

0

您分配buffer的大小为memorysize19189字节)。

但是, 指向的缓冲区page.data会根据 HTTP 请求返回的数据量而增长。但是,无论是否足够大,都将指向的空终止字符串复制page.data到其中。bufferbuffer

也许你应该摆脱所有与你的函数相关的代码buffer并退出你的函数,比如:

jstring retval = (*env)->NewStringUTF(env, page.data);
free(page.data);
return retval;

不要忘记在response_code != 200.

其他一些评论:

  • 我看不到如何webpage设置或声明-我假设GetStringUTFChars()您的真实代码中有一个省略的调用?
  • 我不熟悉 JNI,所以我可能没有正确处理jstring上面建议中的结果。
  • 我很好奇 - 当您使用 curl 命令行工具将 HTTP 响应放入文件时,文件最终有多大?
于 2013-11-12T07:20:15.617 回答
0

我遇到了同样的问题,通过扩展 CURLOPT_TIMEOUT_MS 为我解决了这个问题。

于 2018-10-11T11:29:31.523 回答