PHP的curl函數(shù)的用法總結
要使用cURL來發(fā)送url請求,具體步驟大體分為以下四步:
- 初始化
- 設置請求選項
- 執(zhí)行一個cURL會話并且獲取相關回復
- 釋放cURL句柄,關閉一個cURL會話
curl基礎例子:
<?php // 創(chuàng)建一個新cURL資源 $ch = curl_init(); // 設置URL和相應的選項 curl_setopt($ch, CURLOPT_URL, "http://www.example.com/"); curl_setopt($ch, CURLOPT_HEADER, false); // 抓取URL并把它傳遞給瀏覽器 curl_exec($ch); //關閉cURL資源,并且釋放系統(tǒng)資源 curl_close($ch); ?>
curl函數(shù):
•curl_close — 關閉一個cURL會話
•curl_copy_handle — 復制一個cURL句柄和它的所有選項
•curl_errno — 返回最后一次的錯誤號
•curl_error — 返回一個保護當前會話最近一次錯誤的字符串
•curl_escape — 使用 URL 編碼給定的字符串
•curl_exec — 執(zhí)行一個cURL會話
•curl_file_create — 創(chuàng)建一個 CURLFile 對象
•curl_getinfo — 獲取一個cURL連接資源句柄的信息
•curl_init — 初始化一個cURL會話
•curl_multi_add_handle — 向curl批處理會話中添加單獨的curl句柄
•curl_multi_close — 關閉一組cURL句柄
•curl_multi_exec — 運行當前 cURL 句柄的子連接
•curl_multi_getcontent — 如果設置了CURLOPT_RETURNTRANSFER,則返回獲取的輸出的文本流
•curl_multi_info_read — 獲取當前解析的cURL的相關傳輸信息
•curl_multi_init — 返回一個新cURL批處理句柄
•curl_multi_remove_handle — 移除curl批處理句柄資源中的某個句柄資源
•curl_multi_select — 等待所有cURL批處理中的活動連接
•curl_multi_setopt — 為 cURL 并行處理設置一個選項
•curl_multi_strerror — Return string describing error code
•curl_pause — Pause and unpause a connection
•curl_reset — 重置一個 libcurl 會話句柄的所有的選項
•curl_setopt_array — 為cURL傳輸會話批量設置選項
•curl_setopt — 設置一個cURL傳輸選項
•curl_share_close — Close a cURL share handle
•curl_share_init — Initialize a cURL share handle
•curl_share_setopt — Set an option for a cURL share handle.
•curl_strerror — Return string describing the given error code
•curl_unescape — 解碼給定的 URL 編碼的字符串
•curl_version — 獲取cURL版本信息
一些參數(shù)參考
下列選項的值將被作為長整形使用(在option參數(shù)中指定):
CURLOPT_INFILESIZE: 當你上傳一個文件到遠程站點,這個選項告訴PHP你上傳文件的大小。
CURLOPT_VERBOSE: 如果你想CURL報告每一件意外的事情,設置這個選項為一個非零值。
CURLOPT_HEADER: 如果你想把一個頭包含在輸出中,設置這個選項為一個非零值。
CURLOPT_NOPROGRESS: 如果你不會PHP為CURL傳輸顯示一個進程條,設置這個選項為一個非零值。
注意:PHP自動設置這個選項為非零值,你應該僅僅為了調試的目的來改變這個選項。
CURLOPT_NOBODY: 如果你不想在輸出中包含body部分,設置這個選項為一個非零值。
CURLOPT_FAILONERROR: 如果你想讓PHP在發(fā)生錯誤(HTTP代碼返回大于等于300)時,不顯示,設置這個選項為一人非零值。默認行為是返回一個正常頁,忽略代碼。
CURLOPT_UPLOAD: 如果你想讓PHP為上傳做準備,設置這個選項為一個非零值。
CURLOPT_POST: 如果你想PHP去做一個正規(guī)的HTTP POST,設置這個選項為一個非零值。這個POST是普通的 application/x-www-from-urlencoded 類型,多數(shù)被HTML表單使用。
CURLOPT_FTPLISTONLY: 設置這個選項為非零值,PHP將列出FTP的目錄名列表。
CURLOPT_FTPAPPEND: 設置這個選項為一個非零值,PHP將應用遠程文件代替覆蓋它。
CURLOPT_NETRC: 設置這個選項為一個非零值,PHP將在你的 ~./netrc 文件中查找你要建立連接的遠程站點的用戶名及密碼。
CURLOPT_FOLLOWLOCATION: 設置這個選項為一個非零值(象 ‘Location: ‘)的頭,服務器會把它當做HTTP頭的一部分發(fā)送(注意這是遞歸的,PHP將發(fā)送形如 ‘Location: ‘的頭)。
CURLOPT_PUT: 設置這個選項為一個非零值去用HTTP上傳一個文件。要上傳這個文件必須設置CURLOPT_INFILE和CURLOPT_INFILESIZE選項.
CURLOPT_MUTE: 設置這個選項為一個非零值,PHP對于CURL函數(shù)將完全沉默。
CURLOPT_TIMEOUT: 設置一個長整形數(shù),作為最大延續(xù)多少秒。
CURLOPT_LOW_SPEED_LIMIT: 設置一個長整形數(shù),控制傳送多少字節(jié)。
CURLOPT_LOW_SPEED_TIME: 設置一個長整形數(shù),控制多少秒傳送CURLOPT_LOW_SPEED_LIMIT規(guī)定的字節(jié)數(shù)。
CURLOPT_RESUME_FROM: 傳遞一個包含字節(jié)偏移地址的長整形參數(shù),(你想轉移到的開始表單)。
CURLOPT_SSLVERSION: 傳遞一個包含SSL版本的長參數(shù)。默認PHP將被它自己努力的確定,在更多的安全中你必須手工設置。
CURLOPT_TIMECONDITION: 傳遞一個長參數(shù),指定怎么處理CURLOPT_TIMEVALUE參數(shù)。你可以設置這個參數(shù)為TIMECOND_IFMODSINCE 或 TIMECOND_ISUNMODSINCE。這僅用于HTTP。
CURLOPT_TIMEVALUE: 傳遞一個從1970-1-1開始到現(xiàn)在的秒數(shù)。這個時間將被CURLOPT_TIMEVALUE選項作為指定值使用,或被默認TIMECOND_IFMODSINCE使用。
下列選項的值將被作為字符串:
CURLOPT_URL: 這是你想用PHP取回的URL地址。你也可以在用curl_init()函數(shù)初始化時設置這個選項。
CURLOPT_USERPWD: 傳遞一個形如[username]:[password]風格的字符串,作用PHP去連接。
CURLOPT_PROXYUSERPWD: 傳遞一個形如[username]:[password] 格式的字符串去連接HTTP代理。
CURLOPT_RANGE: 傳遞一個你想指定的范圍。它應該是'X-Y'格式,X或Y是被除外的。HTTP傳送同樣支持幾個間隔,用逗句來分隔(X-Y,N-M)。
CURLOPT_POSTFIELDS: 傳遞一個作為HTTP “POST”操作的所有數(shù)據(jù)的字符串。
CURLOPT_REFERER: 在HTTP請求中包含一個'referer'頭的字符串。
CURLOPT_USERAGENT: 在HTTP請求中包含一個'user-agent'頭的字符串。
CURLOPT_FTPPORT: 傳遞一個包含被ftp ‘POST'指令使用的IP地址。這個POST指令告訴遠程服務器去連接我們指定的IP地址。 這個字符串可以是一個IP地址,一個主機名,一個網(wǎng)絡界面名(在UNIX下),或是‘-'(使用系統(tǒng)默認IP地址)。
CURLOPT_COOKIE: 傳遞一個包含HTTP cookie的頭連接。
CURLOPT_SSLCERT: 傳遞一個包含PEM格式證書的字符串。
CURLOPT_SSLCERTPASSWD: 傳遞一個包含使用CURLOPT_SSLCERT證書必需的密碼。
CURLOPT_COOKIEFILE: 傳遞一個包含cookie數(shù)據(jù)的文件的名字的字符串。這個cookie文件可以是Netscape格式,或是堆存在文件中的HTTP風格的頭。
CURLOPT_CUSTOMREQUEST: 當進行HTTP請求時,傳遞一個字符被GET或HEAD使用。為進行DELETE或其它操作是有益的,更Pass a string to be used instead of GET or HEAD when doing an HTTP request. This is useful for doing or another, more obscure, HTTP request.
注意: 在確認你的服務器支持命令先不要去這樣做。
下列的選項要求一個文件描述(通過使用fopen()函數(shù)獲得):
CURLOPT_FILE: 這個文件將是你放置傳送的輸出文件,默認是STDOUT.
CURLOPT_INFILE: 這個文件是你傳送過來的輸入文件。
CURLOPT_WRITEHEADER: 這個文件寫有你輸出的頭部分。
CURLOPT_STDERR: 這個文件寫有錯誤而不是stderr。
相關文章
Zend Framework自定義Helper類相關注意事項總結
這篇文章主要介紹了Zend Framework自定義Helper類相關注意事項,總結分析了編寫自定義Helper類的相關原則與實現(xiàn)技巧,需要的朋友可以參考下2016-03-03php中使用cookie來保存用戶登錄信息的實現(xiàn)代碼
php中使用cookie來保存用戶登錄信息的實現(xiàn)代碼,使用php開發(fā)的朋友可以參考下2012-03-03PHP中設置一個嚴格30分鐘過期Session面試題的4種答案
這篇文章主要介紹了PHP中設置一個嚴格30分鐘過期Session面試題的4種答案,需要的朋友可以參考下2014-07-07laravel框架模型中非靜態(tài)方法也能靜態(tài)調用的原理分析
這篇文章主要介紹了laravel框架模型中非靜態(tài)方法也能靜態(tài)調用的原理,結合實例形式分析了laravel模型基類中使用魔術方法實現(xiàn)非靜態(tài)方法進行靜態(tài)調用的相關原理,需要的朋友可以參考下2019-11-11PHP使用Apache的偽靜態(tài)功能實現(xiàn)“網(wǎng)頁404時跳轉指定頁面
這篇文章主要介紹了PHP使用Apache的偽靜態(tài)功能實現(xiàn)“網(wǎng)頁404時跳轉指定頁面,這是比較常見的頁面,文中的方法可以很好的解決,有需要的同學可以借鑒下2021-03-03Drupal7連接多個數(shù)據(jù)庫及常見問題解決
這篇文章主要介紹了Drupal7連接多個數(shù)據(jù)庫的方法、操作實例,以及常見問題解決方法,需要的朋友可以參考下2014-03-03