1.cURL介紹
cURL 是一個利用URL語法規(guī)定來傳輸文件和數(shù)據(jù)的工具,支持很多協(xié)議,如HTTP、FTP、TELNET等。最爽的是,PHP也支持 cURL 庫。本文將介紹 cURL 的一些高級特性,以及在PHP中如何運用它。
2.基本結(jié)構(gòu)
在學(xué)習(xí)更為復(fù)雜的功能之前,先來看一下在PHP中建立cURL請求的基本步驟:
?。?)初始化
curl_init()
(2)設(shè)置變量
curl_setopt() 。最為重要,一切玄妙均在此。有一長串cURL參數(shù)可供設(shè)置,它們能指定URL請求的各個細節(jié)。要一次性全部看完并理解可能比較困難,所以今天我們只試一下那些更常用也更有用的選項。
(3)執(zhí)行并獲取結(jié)果
curl_exec()
?。?)釋放cURL句柄
curl_close()
使用CURL發(fā)送請求的基本流程
使用CURL的PHP擴展完成一個HTTP請求的發(fā)送一般有以下幾個步驟:
1.初始化連接句柄;
2.設(shè)置CURL選項;
3.執(zhí)行并獲取結(jié)果;
4.釋放VURL連接句柄。
下面的程序片段是使用CURL發(fā)送HTTP的典型過程
// 1. 初始化 $ch = curl_init(); // 2. 設(shè)置選項,包括URL curl_setopt($ch,CURLOPT_URL,"http://www.devdo.net"); 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);
上述代碼中使用到了四個函數(shù)
①CURLOPT_URL 指定請求的URL;
②CURLOPT_RETURNTRANSFER 設(shè)置為1表示稍后執(zhí)行的curl_exec函數(shù)的返回是URL的返回字符串,而不是把返回字符串定向到標準輸出并返回TRUE;
③CURLLOPT_HEADER設(shè)置為0表示不返回HTTP頭部信息。
CURL的選項還有很多,可以到PHP的官方網(wǎng)站(http://www.php.net/manual/en/function.curl-setopt.php)上查看CURL支持的所有選項列表。
獲取CURL請求的輸出信息
在curl_exec()函數(shù)執(zhí)行之后,可以使用curl_getinfo()函數(shù)獲取CURL請求輸出的相關(guān)信息,示例代碼如下:
curl_exec($ch); $info = curl_getinfo($sh); echo ' 獲取 '.$info['url'].'耗時'.$info['total_time'].'秒';
上述代碼中curl_getinfo返回的是一個關(guān)聯(lián)數(shù)組,包含以下數(shù)據(jù):
curl_getinfo()函數(shù)還有一個可選擇參數(shù)$opt,通過這個參數(shù)可以設(shè)置一些常量,對應(yīng)到上術(shù)這個字段,如果設(shè)置了第二個參數(shù),那么返回的只有指定的信息。例如設(shè)置$opt為CURLINFO_TOTAL_TIME,則curl_getinfo()函數(shù)只返回total_time,即總傳輸消耗的時間,在只需要關(guān)注某些傳輸信息時,設(shè)置$opt參數(shù)很有意義。
使用CURL發(fā)送GET請求
如何使用CURL來發(fā)送GET請求,發(fā)送GET請求的關(guān)鍵是拼裝格式正確的URL。請求地址和GET數(shù)據(jù)由一個“?”分割,然后GET變量的名稱和值用“=”分隔,各個GET名稱和值由“&”連接。PHP為我們提供了一個函數(shù)專門用來拼裝GET請求和數(shù)據(jù)部分——http_build_query,該函數(shù)接受一個關(guān)聯(lián)數(shù)組,返回由該關(guān)聯(lián)數(shù)據(jù)描述的GET請求字符串。使用這個函數(shù),結(jié)合CURL發(fā)送HTTP請求的一般流程,我們封閉了一個發(fā)送GET請求的函數(shù)——doCurlGetRequest,具體代碼如下:
/** *@desc 封閉curl的調(diào)用接口,get的請求方式。 */ 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); }
這個函數(shù)把使用http_build_query 拼裝好的帶GET參數(shù)的URL傳給curl_init函數(shù),然后使用CURL發(fā)送HTTP請求。
使用CURL發(fā)送POST請求
可以使用CURL提供的選項CURLOPT_POSTFIELDS,設(shè)置該選項為POST字符串數(shù)據(jù)就可以把請求放在正文中。同樣我們實現(xiàn)了一個發(fā)送POST請求的函數(shù)——doCurlPostRequest,代碼如下:
/** ** @desc 封裝 curl 的調(diào)用接口,post的請求方式 **/ 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,標識這個請求是一個POST請求。在POST請求中也是可以傳輸GET數(shù)據(jù)的,只需要在URL中拼裝GET請求數(shù)據(jù)即可。
3.cURL實現(xiàn)Get和Post
3.1 Get方式實現(xiàn)
//初始化 $ch = curl_init();
//設(shè)置選項,包括URL curl_setopt($ch, CURLOPT_URL, "http://theartemis.cn"); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HEADER, 0);
//執(zhí)行并獲取HTML文檔內(nèi)容 $output = curl_exec($ch);
//釋放curl句柄 curl_close($ch);
//打印獲得的數(shù)據(jù) print_r($output);
3.2 Post方式實現(xiàn)$url = "http://localhost/web_services.php"; $post_data = array ("username" => "bob","key" => "12345");
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); // post數(shù)據(jù) curl_setopt($ch, CURLOPT_POST, 1); // post的變量 curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
$output = curl_exec($ch); curl_close($ch);
//打印獲得的數(shù)據(jù) print_r($output);
以上方式獲取到的數(shù)據(jù)是json格式的,使用json_decode函數(shù)解釋成數(shù)組。
$output_array = json_decode($output,true);
如果使用json_decode($output)解析的話,將會得到object類型的數(shù)據(jù)。
如對本文有疑問,請?zhí)峤坏浇涣髡搲瑥V大熱心網(wǎng)友會為你解答??! 點擊進入論壇