推荐:《PHP视频教程》

PHP网络爬虫实践:抓取百度搜索结果,并分析数据结构

百度的搜索引擎有反爬虫机制,我先直接用guzzle试试水。代码如下:

<?php/** * Created by Benjiemin * Date: 2020/3/5 * Time: 14:58 */require ('./vendor/autoload.php');use QL\QueryList;//进入网页$jar = new \GuzzleHttp\Cookie\CookieJar;$client = new GuzzleHttp\Client(['cookies' => true]);$ql = $client->request('GET', 'https://www.baidu.com', [    'cookies' => $jar]);if($ql->getStatusCode()!=200){    echo '网站状态不正常';die;}echo  $ql->getBody();

6b0d42b0ac5af250f8026e0f3ff8423.png

百度直接拦截了,进了跳转页面,我试试加个浏览器头文件,再试试。

修改后的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',]]);

我测试了下,网站打开了。

8e377d524c553551086d93d9f40c90b.png

我们继续,输入关键词,并搜索,结果发现被安全拦截了,所以我感觉直接用GuzzleHttp搞不动,于是我继续我的神器:jaeger/querylist和jaeger/querylist-puppeteer。

安装步骤:

1.安装依赖

在这之前,要先启用php的proc_open函数,否则无法安装完整

composer install jaeger/querylistcomposer 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 QL\QueryList;use QL\Ext\Chrome;$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是我的结果集合,打印下,如下

b8484929df81399679d8932930690fd.png

57c970e6dcf42d1a286ea23682e0591.png

更多相关文章

  1. php跳转不改变浏览器地址
  2. 命令行下可以跑PHP脚本,但是通过浏览器却不能跑?
  3. PHP使用swoole实现多线程爬虫
  4. 微软Edge浏览器准备内置屏蔽广告功能
  5. 社会化海量数据采集爬虫框架搭建
  6. 博客网站显示框相对浏览器固定位置显示
  7. 用 cURL 请求测试 ETag 浏览器缓存[每日前端夜话0xCC]
  8. jQuery的$.getJSON方法在IE浏览器下失效的解决方案

随机推荐

  1. 我的Android进阶之旅------>Android 众多
  2. 浅析Android手机卫士读取联系人
  3. 转:打造一款 Android 联网 tic-tac-toe 游
  4. 关于android的id
  5. Android:常用属性整理
  6. Android画图之Bitmap(二)
  7. Android的UI结构试图工具hierarchyviewer
  8. Android Studio开发指南
  9. Android中animation方面知识: Android:int
  10. Realtek 8192cu 支持 Android Hotspot