PHP CURL使用詳解
PHP CURL是一個(gè)非常強(qiáng)大的開(kāi)源庫(kù),支持很多協(xié)議,包括HTTP、FTP、TELNET等,我們使用它來(lái)發(fā)送HTTP請(qǐng)求。它給我們帶來(lái)的好處是可以通過(guò)靈活的選項(xiàng)設(shè)置不同的HTTP協(xié)議參數(shù),并且支持HTTPS。CURL可以根據(jù)URL前綴是“HTTP” 還是“HTTPS”自動(dòng)選擇是否加密發(fā)送內(nèi)容。
使用CURL發(fā)送請(qǐng)求的基本流程
使用CURL的PHP擴(kuò)展完成一個(gè)HTTP請(qǐng)求的發(fā)送一般有以下幾個(gè)步驟:
- 1、初始化連接句柄;
- 2、設(shè)置CURL選項(xiàng);
- 3、執(zhí)行并獲取結(jié)果;
- 4、釋放VURL連接句柄。
下面的程序片段是使用CURL發(fā)送HTTP的典型過(guò)程
// 1. 初始化
$ch = curl_init();
// 2. 設(shè)置選項(xiàng),包括URL
curl_setopt($ch,CURLOPT_URL,"http://www.codetc.com");
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_HEADER,0);
// 3. 執(zhí)行并獲取HTML文檔內(nèi)容
$output = curl_exec($ch);
if($output === FALSE ){
echo "CURL Error:".curl_error($ch);
}
// 4. 釋放curl句柄
curl_close($ch);
上述代碼中使用到了四個(gè)函數(shù)
curl_init() 和 curl_close() 分別是初始化CURL連接和關(guān)閉CURL連接,都比較簡(jiǎn)單。
curl_exec() 執(zhí)行CURL請(qǐng)求,如果沒(méi)有錯(cuò)誤發(fā)生,該函數(shù)的返回是對(duì)應(yīng)URL返回的數(shù)據(jù),以字符串表示滿(mǎn)意;如果發(fā)生錯(cuò)誤,該函數(shù)返回 FALSE。需要注意的是,判斷輸出是否為FALSE用的是全等號(hào),這是為了區(qū)分返回空串和出錯(cuò)的情況。
CURL函數(shù)庫(kù)里最重要的函數(shù)是curl_setopt(),它可以通過(guò)設(shè)定CURL函數(shù)庫(kù)定義的選項(xiàng)來(lái)定制HTTP請(qǐng)求。上述代碼片段中使用了三個(gè)重要的選項(xiàng):
- CURLOPT_URL 指定請(qǐng)求的URL;
- CURLOPT_RETURNTRANSFER 設(shè)置為1表示稍后執(zhí)行的curl_exec函數(shù)的返回是URL的返回字符串,而不是把返回字符串定向到標(biāo)準(zhǔn)輸出并返回TRUE;
- CURLLOPT_HEADER設(shè)置為0表示不返回HTTP頭部信息。
CURL的選項(xiàng)還有很多,可以到PHP的官方網(wǎng)站(http://www.php.net/manual/en/function.curl-setopt.php)上查看CURL支持的所有選項(xiàng)列表。
獲取CURL請(qǐng)求的輸出信息
在curl_exec()函數(shù)執(zhí)行之后,可以使用curl_getinfo()函數(shù)獲取CURL請(qǐng)求輸出的相關(guān)信息,示例代碼如下:
curl_exec($ch); $info = curl_getinfo($sh); echo ' 獲取 '.$info['url'].'耗時(shí)'.$info['total_time'].'秒';
上述代碼中curl_getinfo返回的是一個(gè)關(guān)聯(lián)數(shù)組,包含以下數(shù)據(jù):
- url:網(wǎng)絡(luò)地址。
- content_type:內(nèi)容編碼。
- http_code:HTTP狀態(tài)碼。
- header_size:header的大小。
- request_size:請(qǐng)求的大小。
- filetime:文件創(chuàng)建的時(shí)間。
- ssl_verify_result:SSL驗(yàn)證結(jié)果。
- redirect_count:跳轉(zhuǎn)計(jì)數(shù)。
- total_time:總耗時(shí)。
- namelookup_time:DNS查詢(xún)耗時(shí)。
- connect_time:等待連接耗時(shí)。
- pretransfer_time:傳輸前準(zhǔn)備耗時(shí)。
- size_uplpad:上傳數(shù)據(jù)的大小。
- size_download:下載數(shù)據(jù)的大小。
- speed_download:下載速度。
- speed_upload:上傳速度。
- download_content_length:下載內(nèi)容的長(zhǎng)度。
- upload_content_length:上傳內(nèi)容的長(zhǎng)度。
- starttransfer_time:開(kāi)始傳輸?shù)臅r(shí)間表。
- redirect_time:重定向耗時(shí)。
curl_getinfo()函數(shù)還有一個(gè)可選擇參數(shù)$opt,通過(guò)這個(gè)參數(shù)可以設(shè)置一些常量,對(duì)應(yīng)到上術(shù)這個(gè)字段,如果設(shè)置了第二個(gè)參數(shù),那么返回的只有指定的信息。例如設(shè)置$opt為CURLINFO_TOTAL_TIME,則curl_getinfo()函數(shù)只返回total_time,即總傳輸消耗的時(shí)間,在只需要關(guān)注某些傳輸信息時(shí),設(shè)置$opt參數(shù)很有意義。
使用CURL發(fā)送GET請(qǐng)求
如何使用CURL來(lái)發(fā)送GET請(qǐng)求,發(fā)送GET請(qǐng)求的關(guān)鍵是拼裝格式正確的URL。請(qǐng)求地址和GET數(shù)據(jù)由一個(gè)“?”分割,然后GET變量的名稱(chēng)和值用“=”分隔,各個(gè)GET名稱(chēng)和值由“&”連接。PHP為我們提供了一個(gè)函數(shù)專(zhuān)門(mén)用來(lái)拼裝GET請(qǐng)求和數(shù)據(jù)部分——http_build_query,該函數(shù)接受一個(gè)關(guān)聯(lián)數(shù)組,返回由該關(guān)聯(lián)數(shù)據(jù)描述的GET請(qǐng)求字符串。使用這個(gè)函數(shù),結(jié)合CURL發(fā)送HTTP請(qǐng)求的一般流程,我們封閉了一個(gè)發(fā)送GET請(qǐng)求的函數(shù)——doCurlGetRequest,具體代碼如下:
/**
*@desc 封閉curl的調(diào)用接口,get的請(qǐng)求方式。
*/
function doCurlGetRequest($url,$data,$timeout = 5){
if($curl == "" || $timeout <= 0){
return false;
}
$url = $url.'?'.http_bulid_query($data);
$con = curl_init((string)$url);
curl_setopt($con, CURLOPT_HEADER, false);
curl_setopt($con, CURLOPT_RETURNTRANSFER,true);
curl_setopt($con, CURLOPT_TIMEOUT, (int)$timeout);
return curl_exec($con);
}
這個(gè)函數(shù)把使用http_build_query 拼裝好的帶GET參數(shù)的URL傳給curl_init函數(shù),然后使用CURL發(fā)送HTTP請(qǐng)求。
使用CURL發(fā)送POST請(qǐng)求
可以使用CURL提供的選項(xiàng)CURLOPT_POSTFIELDS,設(shè)置該選項(xiàng)為POST字符串?dāng)?shù)據(jù)就可以把請(qǐng)求放在正文中。同樣我們實(shí)現(xiàn)了一個(gè)發(fā)送POST請(qǐng)求的函數(shù)——doCurlPostRequest,代碼如下:
/**
** @desc 封裝 curl 的調(diào)用接口,post的請(qǐng)求方式
**/
function doCurlPostRequest($url,$requestString,$timeout = 5){
if($url == '' || $requestString == '' || $timeout <=0){
return false;
}
$con = curl_init((string)$url);
curl_setopt($con, CURLOPT_HEADER, false);
curl_setopt($con, CURLOPT_POSTFIELDS, $requestString);
curl_setopt($con, CURLOPT_POST,true);
curl_setopt($con, CURLOPT_RETURNTRANSFER,true);
curl_setopt($con, CURLOPT_TIMEOUT,(int)$timeout);
return curl_exec($con);
}
上面代碼中除了設(shè)置CURLOPT_POSTFIELDS外,我們還設(shè)置了CURL_POST為true,標(biāo)識(shí)這個(gè)請(qǐng)求是一個(gè)POST請(qǐng)求。在POST請(qǐng)求中也是可以傳輸GET數(shù)據(jù)的,只需要在URL中拼裝GET請(qǐng)求數(shù)據(jù)即可秀。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
php中array_pad()函數(shù)用法及實(shí)例
在本篇文章里小編給大家整理的是一篇關(guān)于php中array_pad()函數(shù)用法及實(shí)例內(nèi)容,有興趣的朋友們可以跟著學(xué)習(xí)下。2021-08-08
PHP精確到毫秒秒殺倒計(jì)時(shí)實(shí)例詳解
這篇文章主要介紹了PHP精確到毫秒秒殺倒計(jì)時(shí)實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
php 模擬 asp.net webFrom 按鈕提交事件的思路及代碼
這篇文章主要介紹了php模擬asp.net webFrom 按鈕提交事件的思路及代碼,有需要的朋友可以參考一下2013-12-12
php采用curl訪(fǎng)問(wèn)域名返回405 method not allowed提示的解決方法
這篇文章主要介紹了php采用curl訪(fǎng)問(wèn)域名返回405 method not allowed提示的解決方法,需要的朋友可以參考下2014-06-06
php中html_entity_decode實(shí)現(xiàn)HTML實(shí)體轉(zhuǎn)義
這篇文章主要介紹了php中html_entity_decode實(shí)現(xiàn)HTML實(shí)體轉(zhuǎn)義的相關(guān)資料,需要的朋友可以參考下2018-06-06

