PHP は Baidu の検索結果のクロールを実装し、データ構造を分析します

PHP中文网
リリース: 2023-04-09 15:28:01
転載
6156 人が閲覧しました

PHP は Baidu の検索結果のクロールを実装し、データ構造を分析します

#推奨: 「

PHP ビデオ チュートリアル

PHP Web クローラーの実践: Baidu の検索結果をクロールし、データ構造を分析する

Baidu の検索エンジンにはクローラー対策機能があるので、まずは guzzle で直接試してみます。コードは次のとおりです:

 true]); $ql = $client->request('GET', 'https://www.baidu.com', [ 'cookies' => $jar ]); if($ql->getStatusCode()!=200){ echo '网站状态不正常';die; } echo $ql->getBody();
ログイン後にコピー

PHP は Baidu の検索結果のクロールを実装し、データ構造を分析します

Baidu が直接インターセプトしてジャンプ ページに入りました。ブラウザのヘッダー ファイルを追加して再試行してみます。

変更されたヘッダーは次のとおりです:

$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', ] ]);
ログイン後にコピー

テストしたところ、Web サイトが開きました。

PHP は Baidu の検索結果のクロールを実装し、データ構造を分析します

続けて、キーワードを入力して検索してみると、セキュリティによって傍受されていたので、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

を有効にしますコードは次のとおりです次のように:

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 は Baidu の検索結果のクロールを実装し、データ構造を分析します

PHP は Baidu の検索結果のクロールを実装し、データ構造を分析します

以上がPHP は Baidu の検索結果のクロールを実装し、データ構造を分析しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
php
ソース:cnblogs.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!