過(guò)幾天網(wǎng)站就要上線了。
最近完成了一個(gè)小功能,就是lol數(shù)據(jù)獲取,
比如:我給你一個(gè)號(hào),你把這個(gè)號(hào)是否打過(guò)排位?戰(zhàn)斗力是多少?勝率和所在的總場(chǎng)數(shù)數(shù)據(jù)獲取過(guò)來(lái)
數(shù)據(jù)都在多玩的網(wǎng)站上可查,所以該做的功能就是遠(yuǎn)程抓取。
功能沒(méi)啥亮點(diǎn),就是簡(jiǎn)單的實(shí)現(xiàn)。
反正就是js不能跨域,然后用php去跨域,用file_get_content好類(lèi)或者是curl好,都不重要。重要是的能理解業(yè)務(wù)流程。
上面這個(gè)圖就是執(zhí)行業(yè)務(wù)流程圖。清楚流程了,然后代碼就好寫(xiě)了
當(dāng)然說(shuō)了,這里就,重點(diǎn)是php怎么去抓取數(shù)據(jù)的。
這里要介紹一款非常好的php類(lèi),simple_html_dom(自行百度獲取文檔)
代碼如下:
public function getdata(){
$server = isset($_post['gameserver'])?trim($_post['gameserver']):null;
$name = isset($_post['gamename'])?trim($_post['gamename']):null;
import(@.org.simplehtmldom); //數(shù)據(jù)抓取類(lèi)
$url = http://lolbox.duowan.com/playerdetail.php?servername=.urlencode($server).&playername=.urlencode($name);
$html = file_get_html($url);
$dom = $html->find('.fighting',0)->children(1);
$result['zdl'] = strip_tags($dom->innertext);
$doms = $html->find('.j_content',0)->children(1);
//echo $html->find(#ranked_tier,0)->innertext;
$temp = $doms->plaintext;
$temparray = explode( ,trim($temp));
foreach($temparray as $key=>$value)
{
if(!empty($value))
{
$temparr[] = trim($value);
}
}
unset($temparray);
//獲取排位類(lèi)型
$pwtype = $temparr[8];
$pwtotal = $temparr[12];
$pwsl = $temparr[14];
if($pwtype == 5v5單雙排)
{
$result['pw'] = $pwtotal;
$result['pwsl'] = $pwsl;
}else{
$result['pw'] = 0;
$result['pwsl'] = 0;
}
$this->ajaxreturn($result) ;
}
上面這些代碼,暴露了哥英語(yǔ)過(guò)了四級(jí)但還是硬傷的bug。
上面這個(gè)類(lèi)很簡(jiǎn)單,難點(diǎn)在于怎么去分析多玩查詢(xún)頁(yè)面的數(shù)據(jù)。用firebug看看吧。
更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄