libcurl easy接口使用說明

使用libcurl

cURL的easy接口是一個(gè)簡單的同步API,能控制數(shù)據(jù)移動(dòng)過程(使用回調(diào))

示例:

#include <stdio.h>
#include "curl/curl.h"

struct TransFile {
    const char *filename;
    FILE *stream;
};

size_t write_data( void *buffer, size_t size, size_t nmemb, void *stream);

int main()
{
    CURL *curl;
    CURLcode ret;
    struct TransFile transfile = {
        "example.pdf",
        NULL
    };

    curl_global_init(CURL_GLOBAL_DEFAULT);

    curl = curl_easy_init();//初始化一個(gè)curl指針
    if (!curl) {
        printf("couldn't init curl\n");
        return 0;
    }

    //設(shè)置要下載的文件的URL
    curl_easy_setopt(curl,CURLOPT_URL,"http://www.mysite.com/example.pdf");
    
    /*執(zhí)行寫入文件流操作*/
    curl_easy_setopt( curl, CURLOPT_WRITEFUNCTION, write_data);//調(diào)用回調(diào)函數(shù)
    curl_easy_setopt( curl,CURLOPT_WRITEDATA, &transfile);//傳入回調(diào)函數(shù)需要的結(jié)構(gòu)體的指針

    curl_easy_setopt( curl, CURLOPT_VERBOSE, 1L);
    curl_easy_setopt( curl, CURLOPT_USERPWD, "SUREN:SUREN");

    //寫入文件
    ret = curl_easy_perform(curl);

    //釋放curl對象
    curl_easy_cleanup(curl);

    if(ret != CURLE_OK) {
        fprintf(stderr,"%d",ret);
    }

    //關(guān)閉文件流
    if(transfile.stream) {
        fclose(transfile.stream);
    }

    //釋放全局curl對象
    curl_global_cleanup();

    return 0;
}

size_t write_data( void *buffer, size_t size, size_t nmemb, void *stream)
{
    struct TransFile *out = (struct TransFile *)stream;
    printf("2.1\n");
    if(out && (!out->stream)) {
        printf("2.2\n");
        out->stream = fopen(out->filename, "wb");
        printf("2.3\n");
        if(!out -> stream) {
            printf("fopen failed!\n");
            return -1;
        }
    }

    return fwrite(buffer,size,nmemb,out->stream);
}

編譯上面的程序,通過它下載文件(當(dāng)然你需要修改程序中的url)來和通過瀏覽器下載直接對比,結(jié)果見http://www.itdecent.cn/p/50a620d08bc9

接口說明

這些接口通過手冊之類的都可以查到詳細(xì)信息

curl_easy_init()

創(chuàng)建一個(gè)簡單的句柄。

curl_easy_setopt()

為句柄設(shè)置屬性和選項(xiàng),控制即將進(jìn)行的轉(zhuǎn)移和轉(zhuǎn)移方式。例如:curl_easy_setopt(curl,option,value);

屬性說明:
屬性說明:
  • CURLOPT_URL:提供請求中使用的URL

  • CURLOPT_TIMEOUT:設(shè)置允許libcurl傳輸操作花費(fèi)的最大時(shí)間

    curl_easy_setopt(curl, CURLOPT_TIMEOUT, 20L);
    
  • CURLOPT_HTTP_VERSION:設(shè)置HTTP協(xié)議版本,value可選:

    • CURL_HTTP_VERSION_NONE
    • CURL_HTTP_VERSION_1_0
    • CURL_HTTP_VERSION_1_1
    • CURL_HTTP_VERSION_2_0
    • CURL_HTTP_VERSION_2TLS
    • CURL_HTTP_VERSION_2_PRIOR_KNOWLEDGE
  • CURLOPT_CONNECTTIMEOUT

  • CURLOPT_NOPROGRESS:關(guān)閉程序meter

    curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 0L);
    
  • CURLOPT_NOBODY:發(fā)送不帶body的請求

    curl_easy_setopt(curl,CURLOPT_NOBODY,1L);
    
  • CURLOPT_HEADERFUNCTION:使用回調(diào)函數(shù)

    當(dāng)收到頭信息的時(shí),調(diào)用回調(diào)函數(shù)

    static size_t header_callback(char *buffer, size_t size,
                                  size_t nitems, void *userdata)
    {
      /* received header is nitems * size long in 'buffer' NOT ZERO TERMINATED */
      /* 'userdata' is set with CURLOPT_HEADERDATA */
      return nitems * size;
    }
     
    CURL *curl = curl_easy_init();
    if(curl) {
      curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
     
      curl_easy_setopt(curl, CURLOPT_HEADERFUNCTION, header_callback);
     
      curl_easy_perform(curl);
    }
    
  • CURLOPT_WRITEHEADER

  • CURLOPT_WRITEDATA:傳遞給寫回調(diào)的自定義指針

    如果已經(jīng)設(shè)置了CURLOPT_WRITEFUNCTION選項(xiàng),該指針就是傳遞給寫回調(diào)的第4個(gè)參數(shù)

  • CURLOPT_URL

curl_easy_cleanup()

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • =========================================================...
    lavor閱讀 3,646評(píng)論 0 5
  • 轉(zhuǎn)載自:http://www.cnblogs.com/txw1958/archive/2013/01/19/286...
    php_bruce閱讀 2,450評(píng)論 1 5
  • CURLOPT_RETURNTRANSFER 選項(xiàng):curl_setopt($ch, CURLOPT_RETURN...
    Talentisan閱讀 17,134評(píng)論 0 2
  • 正確的價(jià)值”是什么。關(guān)于這一點(diǎn),我有以下四個(gè)觀點(diǎn): 第一,正確本身沒有價(jià)值; 第二,特立獨(dú)行且正確,才具有價(jià)值; ...
    laoqin閱讀 457評(píng)論 0 0
  • 當(dāng)你在說別人沒禮貌的時(shí)候,想想你是否以禮待人;當(dāng)你討厭別人的時(shí)候,想想你是否沒有讓人討厭的地方?,F(xiàn)在好多事正當(dāng)青壯...
    18faa5403bd2閱讀 191評(píng)論 0 0

友情鏈接更多精彩內(nèi)容