站長資訊網
        最全最豐富的資訊網站

        PHP實現抓取百度搜索結果,并分析數據結構

        PHP實現抓取百度搜索結果,并分析數據結構

        推薦:《PHP視頻教程》

        PHP網絡爬蟲實踐:抓取百度搜索結果,并分析數據結構

        百度的搜索引擎有反爬蟲機制,我先直接用guzzle試試水。代碼如下:

        <?php /**  * Created by Benjiemin  * Date: 2020/3/5  * Time: 14:58  */ require ('./vendor/autoload.php'); use QLQueryList; //進入網頁 $jar = new GuzzleHttpCookieCookieJar; $client = new GuzzleHttpClient(['cookies' => true]); $ql = $client->request('GET', 'https://www.baidu.com', [     'cookies' => $jar ]); if($ql->getStatusCode()!=200){     echo '網站狀態不正常';die; } echo  $ql->getBody();

        PHP實現抓取百度搜索結果,并分析數據結構

        百度直接攔截了,進了跳轉頁面,我試試加個瀏覽器頭文件,再試試。

        修改后的header如下:

        $ql = $client->request('GET', 'https://www.baidu.com', [     'cookies' => $jar,     'headers' => [     'Accept-Encoding' => 'gzip, deflate, br',     'Accept'     => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',     'Accept-Language'      => 'zh-CN,zh;q=0.9,en;q=0.8',     'Cache-Control'      => 'no-cache',     'Connection'      => 'keep-alive',     'User-Agent'      => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36', ] ]);

        我測試了下,網站打開了。

        PHP實現抓取百度搜索結果,并分析數據結構

        我們繼續,輸入關鍵詞,并搜索,結果發現被安全攔截了,所以我感覺直接用GuzzleHttp搞不動,于是我繼續我的神器:jaeger/querylist和jaeger/querylist-puppeteer。

        安裝步驟:

        1.安裝依賴

        在這之前,要先啟用php的proc_open函數,否則無法安裝完整

        composer install jaeger/querylist composer install jaeger/querylist-puppeteer

        2.安裝nodejs

        yum install nodejs

        3.安裝npm

        4.安裝@nesk/puphpeteer

        npm install @nesk/puphpeteer

        5.PHP啟用proc_open

        代碼如下:

        <?php /**  * Created by Benjiemin  * Date: 2020/3/5  * Time: 14:58  */ require ('./vendor/autoload.php'); use QLQueryList; use QLExtChrome; $ql = QueryList::getInstance(); // 注冊插件,默認注冊的方法名為: chrome $ql->use(Chrome::class);  $ql->chrome(function ($page,$browser) {     $page->goto('https://www.baidu.com');     // 這里故意設置一個很長的延長時間,讓你可以看到chrome瀏覽器的啟動     sleep(3);     //輸入關鍵詞     $wd = '簡慶旺博客';     $page->type("input[id='kw']",$wd);     sleep(1);     //點擊搜索     $page->click("input[type='submit']");     //等待搜索結果     sleep(3);     //獲取結果     $html = $page->content();     //用jquery選擇器抽取結果     $rules = array(         'title'=>['#content_left h3 a','text'],//標題         'url'=>['#content_left h3 a','href'],//跳轉網址         'description'=>['div .c-abstract','text'],//描述     );     $ql = QueryList::html($html);     $rt = $ql->rules($rules)->query()->getData();     //如果有需要,可以把$rt入庫,以及做其他操作     sleep(10);     $browser->close();     // 返回值一定要是頁面的HTML內容     return $html; },[     'headless' => false, // 啟動可視化Chrome瀏覽器,方便調試     'devtools' => false, // 打開瀏覽器的開發者工具 ])->find('title')->text();

        $rt是我的結果集合,打印下,如下

        PHP實現抓取百度搜索結果,并分析數據結構

        PHP實現抓取百度搜索結果,并分析數據結構

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 亚洲国产精品狼友中文久久久| 日产精品一线二线三线芒果| 日韩精品久久久久久久电影蜜臀| 欧美精品免费观看二区| 亚洲国产精品无码久久久不卡| 国产精品毛片a∨一区二区三区| 8x福利精品第一导航| 无码精品人妻一区二区三区免费看| 精品人妻无码专区中文字幕| 国产韩国精品一区二区三区| 永久免费精品视频| 国产精品999| 国产精品日本一区二区不卡视频| 亚洲色精品88色婷婷七月丁香| 热RE99久久精品国产66热| 国产亚洲精品成人a v小说| 91国内揄拍国内精品情侣对白| 精品亚洲综合久久中文字幕| 91精品国产高清久久久久久io| 国产精品看高国产精品不卡| 欧美精品久久久久久久自慰 | 久久国产精品一国产精品金尊| 亚洲国产另类久久久精品黑人| 午夜成人精品福利网站在线观看| 久久亚洲国产精品123区| 精品无码人妻久久久久久| 国产精品综合久成人| 国产精品自在线拍国产第一页| 国产午夜精品理论片久久| 国产一区二区三区在线观看精品| 成人国产精品秘 果冻传媒在线| 一区二区三区国产精品| 亚洲精品自产拍在线观看动漫| 久热这里只精品99re8久| 99久久99久久精品国产片果冻| 99久久精品免费国产大片| 97精品国产高清自在线看超| 亚洲精品乱码久久久久久蜜桃不卡| 国产精品午夜国产小视频| 国产亚洲精品xxx| 久久Av无码精品人妻系列|