php curl參數詳解與用法大全

來源:互聯網
上載者:User
  1. $cookie_jar = tempnam('./tmp','cookie');
  2. // login
  3. $c=curl_init('http://login_url?username=...
  4. curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
  5. curl_setopt($c, CURLOPT_COOKIEJAR, $cookie_jar);
  6. curl_exec($c);
  7. curl_close($c);
  8. $c="url";
  9. $c=curl_init($c);
  10. curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
  11. curl_setopt($c, CURLOPT_COOKIEFILE, $cookie_jar);
  12. curl_exec($c);
  13. curl_close($c);
  14. ?>
複製代碼

二、post用法注意:post的資料要經過urlencode編碼

  1. $postdata="user=".urlencode($data);
  2. $c=curl_init($c);
  3. curl_setopt($c, CURLOPT_POST, 1);
  4. curl_setopt($c, CURLOPT_POSTFIELDS, $postdata);
  5. curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
  6. curl_exec($c);
  7. curl_close($c);
  8. ?>
複製代碼

CURL詳解curl_close — 關閉一個curl會話curl_copy_handle — 拷貝一個curl串連資源的所有內容和參數curl_errno — 返回一個包含當前會話錯誤資訊的數字編號curl_error — 返回一個包含當前會話錯誤資訊的字串curl_exec — 執行一個curl會話curl_getinfo — 擷取一個curl串連資源控制代碼的資訊curl_init — 初始化一個curl會話

curl_multi_add_handle — 向curl批處理會話中添加單獨的curl控制代碼資源curl_multi_close — 關閉一個批處理控制代碼資源curl_multi_exec — 解析一個curl批處理控制代碼curl_multi_getcontent — 返回擷取的輸出的文字資料流curl_multi_info_read — 擷取當前解析的curl的相關傳輸資訊curl_multi_init — 初始化一個curl批處理控制代碼資源curl_multi_remove_handle — 移除curl批處理控制代碼資源中的某個控制代碼資源curl_multi_select — Get all the sockets associated with the cURL extension, which can then be "selected"curl_setopt_array — 以數組的形式為一個curl設定會話參數curl_setopt — 為一個curl設定會話參數curl_version — 擷取curl相關的版本資訊curl_init()函數的作用初始化一個curl會話,curl_init()函數唯一的一個參數是可選的,表示一個url地址。curl_exec()函數的作用是執行一個curl會話,唯一的參數是curl_init()函數返回的控制代碼。curl_close()函數的作用是關閉一個curl會話,唯一的參數是curl_init()函數返回的控制代碼。

例子:

  1. $ch = curl_init("http://bbs.it-home.org/");
  2. curl_exec($ch);
  3. curl_close($ch);
  4. ?>
複製代碼

curl_version()函數的作用:擷取curl相關的版本資訊,curl_version()函數有一個參數,大家可以測試下。

例子:

  1. print_r(curl_version())
  2. ?>
複製代碼

curl_getinfo()函數的作用是擷取一個curl串連資源控制代碼的資訊,curl_getinfo()函數有兩個參數,第一個參數是curl的資源控制代碼,第二個參數是下面一些常量:

  1. $ch = curl_init("http://bbs.it-home.org/");
  2. print_r(curl_getinfo($ch));
  3. ?>
複製代碼

可選的常量包括:CURLINFO_EFFECTIVE_URL最後一個有效url地址

CURLINFO_HTTP_CODE最後一個收到的HTTP代碼

CURLINFO_FILETIME遠程擷取文檔的時間,如果無法擷取,則傳回值為“-1”

CURLINFO_TOTAL_TIME最後一次傳輸所消耗的時間

CURLINFO_NAMELOOKUP_TIME名稱解析所消耗的時間

CURLINFO_CONNECT_TIME建立串連所消耗的時間

CURLINFO_PRETRANSFER_TIME從建立串連到準備傳輸所使用的時間

CURLINFO_STARTTRANSFER_TIME從建立串連到傳輸開始所使用的時間

CURLINFO_REDIRECT_TIME在事務傳輸開始前重新導向所使用的時間

CURLINFO_SIZE_UPLOAD上傳資料量的總值

CURLINFO_SIZE_DOWNLOAD下載資料量的總值

CURLINFO_SPEED_DOWNLOAD平均下載速度

CURLINFO_SPEED_UPLOAD平均上傳速度

CURLINFO_HEADER_SIZEheader部分的大小

CURLINFO_HEADER_OUT發送請求的字串

CURLINFO_REQUEST_SIZE在HTTP請求中有問題的請求的大小

CURLINFO_SSL_VERIFYRESULTResult of SSL certification verification requested by setting CURLOPT_SSL_VERIFYPEER

CURLINFO_CONTENT_LENGTH_DOWNLOAD從Content-Length: field中讀取的下載內容長度

CURLINFO_CONTENT_LENGTH_UPLOAD上傳內容大小的說明

CURLINFO_CONTENT_TYPE下載內容的“Content-type”值,NULL表示伺服器沒有發送有效“Content-Type: header”

curl_setopt()函數的作用是為一個curl設定會話參數。curl_setopt_array()函數的作用是以數組的形式為一個curl設定會話參數。

例子:

  1. $ch = curl_init();
  2. $fp = fopen("example_homepage.txt", "w");
  3. curl_setopt($ch, CURLOPT_FILE, $fp);
  4. $options = array(
  5. CURLOPT_URL => 'http://bbs.it-home.org/',
  6. CURLOPT_HEADER => false
  7. );
  8. curl_setopt_array($ch, $options);
  9. curl_exec($ch);
  10. curl_close($ch);
  11. fclose($fp);
  12. ?>
複製代碼

可設定的參數有:CURLOPT_AUTOREFERER自動化佈建header中的referer資訊

CURLOPT_BINARYTRANSFER在啟用CURLOPT_RETURNTRANSFER時候將擷取資料返回

CURLOPT_COOKIESESSION啟用時curl會僅僅傳遞一個session cookie,忽略其他的cookie,預設狀況下curl會將所有的cookie返回給服務端。session cookie是指那些用來判斷伺服器端的session是否有效而存在的cookie。

CURLOPT_CRLF啟用時將Unix的分行符號轉換成斷行符號分行符號。

CURLOPT_DNS_USE_GLOBAL_CACHE

啟用時會啟用一個全域的DNS緩衝,此項為安全執行緒的,並且預設為true。

CURLOPT_FAILONERROR

顯示HTTP狀態代碼,預設行為是忽略編號小於等於400的HTTP資訊

CURLOPT_FILETIME

啟用時會嘗試修改遠程文檔中的資訊。結果資訊會通過curl_getinfo()函數的CURLINFO_FILETIME選項返回。

CURLOPT_FOLLOWLOCATION

啟用時會將伺服器伺服器返回的“Location:”放在header中遞迴的返回給伺服器,使用CURLOPT_MAXREDIRS可以限定遞迴返回的數量。

CURLOPT_FORBID_REUSE

在完成互動以後強迫中斷連線,不能重用。

CURLOPT_FRESH_CONNECT

強制擷取一個新的串連,替代緩衝中的串連。

CURLOPT_FTP_USE_EPRT

TRUE to use EPRT (and LPRT) when doing active FTP downloads. Use FALSE to disable EPRT and LPRT and use PORT only.

Added in PHP 5.0.0.

CURLOPT_FTP_USE_EPSV

TRUE to first try an EPSV command for FTP transfers before reverting back to PASV. Set to FALSE to disable EPSV.

CURLOPT_FTPAPPEND

TRUE to append to the remote file instead of overwriting it.

CURLOPT_FTPASCII

An alias of CURLOPT_TRANSFERTEXT. Use that instead.

CURLOPT_FTPLISTONLY

TRUE to only list the names of an FTP directory.

CURLOPT_HEADER

啟用時會將標頭檔的資訊作為資料流輸出。

CURLOPT_HTTPGET

啟用時會設定HTTP的method為GET,因為GET是預設是,所以只在被修改的情況下使用。

CURLOPT_HTTPPROXYTUNNEL

啟用時會通過HTTP代理來傳輸。

CURLOPT_MUTE

講curl函數中所有修改過的參數恢複預設值。

CURLOPT_NETRC

在串連建立以後,訪問~/.netrc檔案擷取使用者名稱和密碼資訊串連遠端站台。

CURLOPT_NOBODY

啟用時將不對HTML中的body部分進行輸出。

CURLOPT_NOPROGRESS

啟用時關閉curl傳輸的進度條,此項的預設設定為true

CURLOPT_NOSIGNAL

啟用時忽略所有的curl傳遞給php進行的訊號。在SAPI多線程傳輸時此項被預設開啟。CURLOPT_POST

啟用時會發送一個常規的POST請求,類型為:application/x-www-form-urlencoded,就像表單提交的一樣。CURLOPT_PUT

啟用時允許HTTP傳送檔案,必須同時設定CURLOPT_INFILE和CURLOPT_INFILESIZECURLOPT_RETURNTRANSFER

講curl_exec()擷取的資訊以檔案流的形式返回,而不是直接輸出。CURLOPT_SSL_VERIFYPEER

FALSE to stop cURL from verifying the peer's certificate. Alternate certificates to verify against can be specified with the CURLOPT_CAINFO option or a certificate directory can be specified with the CURLOPT_CAPATH option. CURLOPT_SSL_VERIFYHOST may also need to be TRUE or FALSE if CURLOPT_SSL_VERIFYPEER is disabled (it defaults to 2). TRUE by default as of cURL 7.10. Default bundle installed as of cURL 7.10.

CURLOPT_TRANSFERTEXT

TRUE to use ASCII mode for FTP transfers. For LDAP, it retrieves data in plain text instead of HTML. On Windows systems, it will not set STDOUT to binary mode.

CURLOPT_UNRESTRICTED_AUTH

在使用CURLOPT_FOLLOWLOCATION產生的header中的多個locations中持續追加使用者名稱和密碼資訊,即使網域名稱已發生改變。

CURLOPT_UPLOAD

啟用時允許檔案傳輸

CURLOPT_VERBOSE

啟用時會彙報所有的資訊,存放在STDERR或指定的CURLOPT_STDERR中

CURLOPT_BUFFERSIZE

每次擷取的資料中讀入緩衝的大小,這個值每次都會被填滿。

CURLOPT_CLOSEPOLICY

不是CURLCLOSEPOLICY_LEAST_RECENTLY_USED就是CURLCLOSEPOLICY_OLDEST,還存在另外三個,但是curl暫時還不支援。.

CURLOPT_CONNECTTIMEOUT

在發起串連前等待的時間,如果設定為0,則不等待。

CURLOPT_DNS_CACHE_TIMEOUT

設定在記憶體中儲存DNS資訊的時間,預設為120秒。

CURLOPT_FTPSSLAUTH

The FTP authentication method (when is activated): CURLFTPAUTH_SSL (try SSL first), CURLFTPAUTH_TLS (try TLS first), or CURLFTPAUTH_DEFAULT (let cURL decide).

CURLOPT_HTTP_VERSION

設定curl使用的HTTP協議,CURL_HTTP_VERSION_NONE(讓curl自己判斷),CURL_HTTP_VERSION_1_0(HTTP/1.0),CURL_HTTP_VERSION_1_1(HTTP/1.1)

CURLOPT_HTTPAUTH 1 2 下一頁 尾頁

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.