0

Web インターフェイスからデータを取得するための libevet プログラムを作成します。次のようなコード: 時々、self->done の evhttp_request *req 構造体が NULL です。この理由がわかりません。

response->connecttime = spi_utils_float_time();
self->evreq = evhttp_request_new(self->done, task);
if (self->evreq == NULL) {
    SPI_LOG_ERROR("spider", "cannot create evhttp_request");
    goto download_error;
}

/* bson_print(&task->task); */

/** set header and body */
/* TODO: set timeout */
spi_http_request_split_header(self, self->header->str, self->evreq);
if (self->body != NULL)
    evbuffer_add_printf(self->evreq->output_buffer, (const char*)self->body->str);

    if (self->method == spi_http_post)
            cmd_type = EVHTTP_REQ_POST;

self->evcon = evhttp_connection_new(self->host->str, self->port);
if (self->evcon == NULL) {
    SPI_LOG_ERROR("spider", "evhttp_connection_new Failed!\n");
    goto download_error;
}

SPI_LOG_DEBUG("spider", "set retries: %d.", 5);
evhttp_connection_set_retries(self->evcon, 3);
SPI_LOG_DEBUG("spider", "set timeout: %d.", 60);
evhttp_connection_set_timeout(self->evcon, 20);

response->connectedtime = spi_utils_float_time();

response->crawltime = spi_utils_float_time();

SPI_LOG_DEBUG("spider", "evhttp_make_request");
if (evhttp_make_request(self->evcon, self->evreq, cmd_type, self->path->str) == -1) {
    SPI_LOG_ERROR("spider", "evhttp_make_request Failed.\n");
    goto download_error;
}
4

1 に答える 1

0

(あなたの質問から、どこで を取得しているのかは完全には明確ではありませんがNULL、おそらくあなたが意味するのはそれです)タイムアウトがあった場合、に
渡されたコールバックevhttp_request_newが取得される可能性があります。NULL

于 2013-07-06T22:46:58.627 に答える