curl大家一定使用過,但并發(fā)使用的情況估計(jì)不多寇窑。但在某些情況下確實(shí)比較有用哎媚,比如在同一請(qǐng)求里面調(diào)用多個(gè)他方接口古胆,傳統(tǒng)方法我們需要串行請(qǐng)求接口:
file_get_contents('http://a.php');//1秒
file_get_contents('http://b.php');//2秒
file_get_contents('http://c.php');//2秒
那在這里耗時(shí)為5秒改鲫,但運(yùn)營curl的muti方法肮街,我們只需2秒就可請(qǐng)求完畢,繼續(xù)處理后面的邏輯.代碼如下:
<?php
$ch = array();
$res = array();
$conn = array();
$urls = array(
'baidu' => "http://www.baidu.com/",
'cheyun' => "http://auto.jrj.com.cn/",
'w3c' => "http://www.w3cschool.cc/",
);
// 創(chuàng)建批處理cURL句柄
$mh = curl_multi_init();
foreach ($urls as $i => $url) {
// 創(chuàng)建一對(duì)cURL資源
$conn[$i] = curl_init(); //初始化各個(gè)子連接
// 設(shè)置URL和相應(yīng)的選項(xiàng)
curl_setopt($conn[$i], CURLOPT_URL, $url);
curl_setopt($conn[$i], CURLOPT_HEADER, 0);
curl_setopt($conn[$i], CURLOPT_RETURNTRANSFER, 1);//不直接輸出到瀏覽器
curl_setopt($conn[$i], CURLOPT_TIMEOUT, 10);
//302跳轉(zhuǎn)
curl_setopt($conn[$i], CURLOPT_FOLLOWLOCATION, 1);
// 增加句柄
curl_multi_add_handle($mh, $conn[$i]);//加入多處理句柄
}
$active = null;//連接數(shù)
//防卡死寫法:執(zhí)行批處理句柄
do {
//這里$active會(huì)被改寫成當(dāng)前未處理數(shù)
//全部處理成功$active會(huì)變成0
$mrc = curl_multi_exec($mh, $active);
//這個(gè)循環(huán)的目的是盡可能的讀寫饮笛,直到無法繼續(xù)讀寫為止(返回CURLM_OK)
//返回(CURLM_CALL_MULTI_PERFORM)就表示還能繼續(xù)向網(wǎng)絡(luò)讀寫
} while ($mrc == CURLM_CALL_MULTI_PERFORM);
//如果一切正常咨察,那么我們要做一個(gè)輪詢,每隔一定時(shí)間(默認(rèn)是1秒)重新請(qǐng)求一次
//這就是curl_multi_select的作用,它在等待過程中福青,如果有就返回目前可以讀寫的句柄數(shù)量,以便
//繼續(xù)讀寫操作,0則沒有可以讀寫的句柄(完成了)
while ($active && $mrc == CURLM_OK) { //直到出錯(cuò)或者全部讀寫完畢
if (curl_multi_select($mh) != -1) {
do {
$mrc = curl_multi_exec($mh, $active);
} while ($mrc == CURLM_CALL_MULTI_PERFORM);
}
}
foreach ($urls as $i => $url) {
//獲取當(dāng)前解析的cURL的相關(guān)傳輸信息
$info = curl_multi_info_read($mh);
//獲取請(qǐng)求頭信息
$heards = curl_getinfo($conn[$i]);
var_dump($heards);
//獲取輸出的文本流
$res[$i] = curl_multi_getcontent($conn[$i]);
// 移除curl批處理句柄資源中的某個(gè)句柄資源
curl_multi_remove_handle($mh, $conn[$i]);
//關(guān)閉cURL會(huì)話
curl_close($conn[$i]);
}
//關(guān)閉全部句柄
curl_multi_close($mh);
//var_dump($res);