來源:不言 發(fā)布時間:2019-03-23 16:04:35 閱讀量:1111
本篇文章給大家?guī)淼膬?nèi)容是關(guān)于PHP的curl函數(shù)的詳細(xì)介紹(總結(jié)),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
要使用cURL來發(fā)送url請求,具體步驟大體分為以下四步:
1.初始化
2.設(shè)置請求選項
3.執(zhí)行一個cURL會話并且獲取相關(guān)回復(fù)
4.釋放cURL句柄,關(guān)閉一個cURL會話
curl基礎(chǔ)例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
curl函數(shù):
?curl_close — 關(guān)閉一個cURL會話
?curl_copy_handle — 復(fù)制一個cURL句柄和它的所有選項
?curl_errno — 返回最后一次的錯誤號
?curl_error — 返回一個保護(hù)當(dāng)前會話最近一次錯誤的字符串
?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 — 關(guān)閉一組cURL句柄
?curl_multi_exec — 運行當(dāng)前 cURL 句柄的子連接
?curl_multi_getcontent — 如果設(shè)置了CURLOPT_RETURNTRANSFER,則返回獲取的輸出的文本流
?curl_multi_info_read — 獲取當(dāng)前解析的cURL的相關(guān)傳輸信息
?curl_multi_init — 返回一個新cURL批處理句柄
?curl_multi_remove_handle — 移除curl批處理句柄資源中的某個句柄資源
?curl_multi_select — 等待所有cURL批處理中的活動連接
?curl_multi_setopt — 為 cURL 并行處理設(shè)置一個選項
?curl_multi_strerror — Return string describing error code
?curl_pause — Pause and unpause a connection
?curl_reset — 重置一個 libcurl 會話句柄的所有的選項
?curl_setopt_array — 為cURL傳輸會話批量設(shè)置選項
?curl_setopt — 設(shè)置一個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: 當(dāng)你上傳一個文件到遠(yuǎn)程站點,這個選項告訴PHP你上傳文件的大小。
CURLOPT_VERBOSE: 如果你想CURL報告每一件意外的事情,設(shè)置這個選項為一個非零值。
CURLOPT_HEADER: 如果你想把一個頭包含在輸出中,設(shè)置這個選項為一個非零值。
CURLOPT_NOPROGRESS: 如果你不會PHP為CURL傳輸顯示一個進(jìn)程條,設(shè)置這個選項為一個非零值。
注意:PHP自動設(shè)置這個選項為非零值,你應(yīng)該僅僅為了調(diào)試的目的來改變這個選項。
CURLOPT_NOBODY: 如果你不想在輸出中包含body部分,設(shè)置這個選項為一個非零值。
CURLOPT_FAILONERROR: 如果你想讓PHP在發(fā)生錯誤(HTTP代碼返回大于等于300)時,不顯示,設(shè)置這個選項為一人非零值。默認(rèn)行為是返回一個正常頁,忽略代碼。
CURLOPT_UPLOAD: 如果你想讓PHP為上傳做準(zhǔn)備,設(shè)置這個選項為一個非零值。
CURLOPT_POST: 如果你想PHP去做一個正規(guī)的HTTP POST,設(shè)置這個選項為一個非零值。這個POST是普通的 application/x-www-from-urlencoded 類型,多數(shù)被HTML表單使用。
CURLOPT_FTPLISTONLY: 設(shè)置這個選項為非零值,PHP將列出FTP的目錄名列表。
CURLOPT_FTPAPPEND: 設(shè)置這個選項為一個非零值,PHP將應(yīng)用遠(yuǎn)程文件代替覆蓋它。
CURLOPT_NETRC: 設(shè)置這個選項為一個非零值,PHP將在你的 ~./netrc 文件中查找你要建立連接的遠(yuǎn)程站點的用戶名及密碼。
CURLOPT_FOLLOWLOCATION: 設(shè)置這個選項為一個非零值(象 ‘Location: ‘)的頭,服務(wù)器會把它當(dāng)做HTTP頭的一部分發(fā)送(注意這是遞歸的,PHP將發(fā)送形如 ‘Location: ‘的頭)。
CURLOPT_PUT: 設(shè)置這個選項為一個非零值去用HTTP上傳一個文件。要上傳這個文件必須設(shè)置CURLOPT_INFILE和CURLOPT_INFILESIZE選項.
CURLOPT_MUTE: 設(shè)置這個選項為一個非零值,PHP對于CURL函數(shù)將完全沉默。
CURLOPT_TIMEOUT: 設(shè)置一個長整形數(shù),作為最大延續(xù)多少秒。
CURLOPT_LOW_SPEED_LIMIT: 設(shè)置一個長整形數(shù),控制傳送多少字節(jié)。
CURLOPT_LOW_SPEED_TIME: 設(shè)置一個長整形數(shù),控制多少秒傳送CURLOPT_LOW_SPEED_LIMIT規(guī)定的字節(jié)數(shù)。
CURLOPT_RESUME_FROM: 傳遞一個包含字節(jié)偏移地址的長整形參數(shù),(你想轉(zhuǎn)移到的開始表單)。
CURLOPT_SSLVERSION: 傳遞一個包含SSL版本的長參數(shù)。默認(rèn)PHP將被它自己努力的確定,在更多的安全中你必須手工設(shè)置。
CURLOPT_TIMECONDITION: 傳遞一個長參數(shù),指定怎么處理CURLOPT_TIMEVALUE參數(shù)。你可以設(shè)置這個參數(shù)為TIMECOND_IFMODSINCE 或 TIMECOND_ISUNMODSINCE。這僅用于HTTP。
CURLOPT_TIMEVALUE: 傳遞一個從1970-1-1開始到現(xiàn)在的秒數(shù)。這個時間將被CURLOPT_TIMEVALUE選項作為指定值使用,或被默認(rèn)TIMECOND_IFMODSINCE使用。
下列選項的值將被作為字符串:
CURLOPT_URL: 這是你想用PHP取回的URL地址。你也可以在用curl_init()函數(shù)初始化時設(shè)置這個選項。
CURLOPT_USERPWD: 傳遞一個形如[username]:[password]風(fēng)格的字符串,作用PHP去連接。
CURLOPT_PROXYUSERPWD: 傳遞一個形如[username]:[password] 格式的字符串去連接HTTP代理。
CURLOPT_RANGE: 傳遞一個你想指定的范圍。它應(yīng)該是’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指令告訴遠(yuǎn)程服務(wù)器去連接我們指定的IP地址。 這個字符串可以是一個IP地址,一個主機(jī)名,一個網(wǎng)絡(luò)界面名(在UNIX下),或是‘-’(使用系統(tǒng)默認(rèn)IP地址)。
CURLOPT_COOKIE: 傳遞一個包含HTTP cookie的頭連接。
CURLOPT_SSLCERT: 傳遞一個包含PEM格式證書的字符串。
CURLOPT_SSLCERTPASSWD: 傳遞一個包含使用CURLOPT_SSLCERT證書必需的密碼。
CURLOPT_COOKIEFILE: 傳遞一個包含cookie數(shù)據(jù)的文件的名字的字符串。這個cookie文件可以是Netscape格式,或是堆存在文件中的HTTP風(fēng)格的頭。
CURLOPT_CUSTOMREQUEST: 當(dāng)進(jìn)行HTTP請求時,傳遞一個字符被GET或HEAD使用。為進(jìn)行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.
注意: 在確認(rèn)你的服務(wù)器支持命令先不要去這樣做。
下列的選項要求一個文件描述(通過使用fopen()函數(shù)獲得):
CURLOPT_FILE: 這個文件將是你放置傳送的輸出文件,默認(rèn)是STDOUT.
CURLOPT_INFILE: 這個文件是你傳送過來的輸入文件。
CURLOPT_WRITEHEADER: 這個文件寫有你輸出的頭部分。
CURLOPT_STDERR: 這個文件寫有錯誤而不是stderr。