色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

使用PHP抓取微博數(shù)據(jù)實現(xiàn)demo及原理解析

瀏覽:5日期:2022-06-14 10:15:05
目錄實現(xiàn)目標使用的工具實現(xiàn)的原理實現(xiàn)目標

1. 用戶發(fā)布的微博內(nèi)容;

2. 用戶發(fā)布的時間;

3. 用戶的名稱; (這里我并沒有獲取)

使用的工具

voku/simple_html_dom x-path

讀取工具 (如果不知道怎么獲取元素的xpath, 請百度這里不做贅述~)

安裝:

composer require voku/simple_html_dom

實現(xiàn)的原理

當(dāng)你去直接用file_get_contents去抓取微博的網(wǎng)頁內(nèi)容時, 你會被它的訪客系統(tǒng)直接攔截, 所以直接用這個方法是不行的;

所以我采用了curl來獲取. 當(dāng)然,直接獲取也是不行的, 所以我們要設(shè)置一下請求頭, 微博對爬蟲類的請求頭是不會拒絕的,

所以你可以直接抓取到網(wǎng)頁;

請求頭設(shè)置如下:

'User-Agent: spider'

代碼如下:

// 通過這段代碼你可以直接獲取到微博的(HTML)網(wǎng)頁 public function curlGetWbData() {// 設(shè)置腳本超時時間set_time_limit(60);// 拉取微博地址$getWbUrl = 'https://weibo.com/p/1005056447467552/home?profile_ftype=1&is_all=1#_0';// 設(shè)置curl 請求頭$header = [ 'User-Agent: spider'];$ch = curl_init(); // 初始化curlcurl_setopt($ch, CURLOPT_URL, $getWbUrl);curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 禁止 cURL 驗證對等證書curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);curl_setopt($ch, CURLOPT_HTTPHEADER, $header); // 設(shè)置請求頭$wbContent = curl_exec($ch);curl_close($ch);// 到這里我們就拿到了微博的網(wǎng)頁return $wbContent; }

拿到微博的網(wǎng)頁內(nèi)容之后, 我們就要對立面的數(shù)據(jù)進行提取, 因為并不是所有的數(shù)據(jù)我們都需要;

這里我們提取 微博內(nèi)容 微博發(fā)布的時間; 現(xiàn)在需要使用x-path來進行提取;

x-path示例:

div[class='WB_cardwrap WB_feed_type S_bg2 WB_feed_like ']

代碼如下:

// 這個方法是public static function actionAddWbData(string $wbContent, string $userID){ $htmlDeal = new HtmlDomParser(); // 處理DOM的對象 $htmlDeal->load($wbContent);// 裝載文本 // 微博VIP和普通用戶的class名不一致 $wbHtml['normal'] = $htmlDeal->find('div[class='WB_cardwrap WB_feed_type S_bg2 WB_feed_like ']'); $wbHtml['vip'] = $htmlDeal->find('div[class='WB_cardwrap WB_feed_type S_bg2 WB_feed_vipcover WB_feed_like ']'); $wbNum = []; foreach ($wbHtml as $item => $key) {if (count($key) <= 0) { continue;}$wbNum[$userID][$item] = self::dealWbContent($key, $userID); } Yii::info('抓取微博日志記錄' . '----' . json_encode($wbNum)); return $wbNum;}

以上就是使用PHP抓取微博數(shù)據(jù)實現(xiàn)demo及原理解析的詳細內(nèi)容,更多關(guān)于PHP抓取微博數(shù)據(jù)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: PHP
主站蜘蛛池模板: 亚洲国产精品一区二区久久 | 国产乱子伦露脸对白在线小说 | 免费永久在线观看黄网 | 国产麻豆福利a v在线播放 | 日本特一级毛片免费视频 | 午夜影院黄色片 | 国产综合视频在线观看一区 | 中文字幕s级优女区 | 亚洲综合一二三区 | 久久黄色免费网站 | 波多野结衣一区在线观看 | 大陆60老妇xxxxhd | 中文字幕一区在线观看 | 成人夜色香网站在线观看 | 欧美亚洲视频 | av中文字幕网免费观看 | 欧美一级片在线观看 | 自拍视频在线观看 | 亚洲精品国产手机 | 久色乳综合思思在线视频 | 日韩欧美一区二区三区免费观看 | 12345国产精品高清在线 | 男女牲高爱潮免费视频男女 | 久久综合99re88久久爱 | 农村寡妇一级毛片免费播放 | 99在线热视频只有精品免费 | 亚洲欧美在线观看视频 | 萌白酱白丝护士服喷水铁牛tv | 全部精品孕妇色视频在线 | 欧美一区精品 | 欧美三级在线看 | 成人午夜视频在线观看 | 男人的天堂在线精品视频 | 在线成人免费视频 | 狠狠色综合久久丁香婷婷 | 小屁孩和大人啪啪 | 久久亚洲国产高清 | 91 久久| 亚洲综合成人网在线观看 | 亚洲精品在线播放 | 亚洲 欧美 成人日韩 |