小編給大家分享一下php使用QueryList輕松采集JavaScript動(dòng)態(tài)渲染頁(yè)面的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比湘陰網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式湘陰網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋湘陰地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。
QueryList使用jQuery的方式來(lái)做采集,擁有豐富的插件。
下面來(lái)演示QueryList使用PhantomJS插件抓取JS動(dòng)態(tài)創(chuàng)建的頁(yè)面內(nèi)容。
安裝
使用Composer安裝:
安裝QueryList
composer require jaeger/querylist GitHub: https://github.com/jae-jae/QueryList
安裝PhantomJS插件
composer require jaeger/querylist-phantomjs GitHub: https://github.com/jae-jae/QueryList-PhantomJS
下載PhantomJS二進(jìn)制文件
PhantomJS官網(wǎng):http://phantomjs.org ,下載對(duì)應(yīng)平臺(tái)的PhantomJS二進(jìn)制文件。
插件API
QueryList browser($url,$debug = false,$commandOpt = []):使用瀏覽器打開連接
使用
以采集「今日頭條」手機(jī)版為例,「今日頭條」手機(jī)版基于React框架,內(nèi)容是純動(dòng)態(tài)渲染出來(lái)的。
下面演示QueryList的PhantomJs插件用法:
安裝插件
use QL\QueryList; use QL\Ext\PhantomJs; $ql = QueryList::getInstance(); // 安裝時(shí)需要設(shè)置PhantomJS二進(jìn)制文件路徑 $ql->use(PhantomJs::class,'/usr/local/bin/phantomjs'); //or Custom function name $ql->use(PhantomJs::class,'/usr/local/bin/phantomjs','browser');
Example-1
獲取動(dòng)態(tài)渲染的HTML:
$html = $ql->browser('https://m.toutiao.com')->getHtml(); print_r($html);
獲取所有p標(biāo)簽文本內(nèi)容:
$data = $ql->browser('https://m.toutiao.com')->find('p')->texts(); print_r($data->all());
輸出:
Array ( [0] => 自拍模式開啟!國(guó)慶假期我和國(guó)旗合個(gè)影 [1] => 你旅途已開始 他們?nèi)栽谧约旱膷徫簧蠟槟愕募倨诒q{護(hù)航 [2] => 喜極而泣,都教授終于回到地球了! //.... )
使用http代理:
// 更多選項(xiàng)可以查看文檔: http://phantomjs.org/api/command-line.html $ql->browser('https://m.toutiao.com',true,[ // 使用http代理 '--proxy' => '192.168.1.42:8080', '--proxy-type' => 'http' ])
Example-2
自定義一個(gè)復(fù)雜的請(qǐng)求:
$data = $ql->browser(function (\JonnyW\PhantomJs\Http\RequestInterface $r){ $r->setMethod('GET'); $r->setUrl('https://m.toutiao.com'); $r->setTimeout(10000); // 10 seconds $r->setDelay(3); // 3 seconds return $r; })->find('p')->texts(); print_r($data->all());
開啟debug模式,并從本地加載cookie文件:
$data = $ql->browser(function (\JonnyW\PhantomJs\Http\RequestInterface $r){ $r->setMethod('GET'); $r->setUrl('https://m.toutiao.com'); $r->setTimeout(10000); // 10 seconds $r->setDelay(3); // 3 seconds return $r; },true,[ '--cookies-file' => '/path/to/cookies.txt' ])->rules([ 'title' => ['p','text'], 'link' => ['a','href'] ])->query()->getData(); print_r($data->all());
看完了這篇文章,相信你對(duì)php使用QueryList輕松采集JavaScript動(dòng)態(tài)渲染頁(yè)面的方法有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)頁(yè)題目:php使用QueryList輕松采集JavaScript動(dòng)態(tài)渲染頁(yè)面的方法
當(dāng)前鏈接:http://jinyejixie.com/article12/ppeogc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、全網(wǎng)營(yíng)銷推廣、建站公司、企業(yè)建站、商城網(wǎng)站、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)