本文實例講述了PHP配合fiddler抓包抓取微信指數小程序數據的實現方法。分享給大家供大家參考,具體如下:
這兩天研究了下微信指數這個東西。要抓取呢,按照一般思路的話,那就是使用fiddler抓取手機包,然后進行分析獲取地址然后請求就可以了。
這么想你是沒錯,如果你果斷這么做了,那就是too yang too simple了。大家可以看下,微信抓取有以下幾個步驟:
1、開始登陸小程序
2、獲取訪問需要的令牌
3、那這令牌去獲取數據
首先的難點就是小程序的登陸那一步。你得先登陸了微信之后才可以訪問小程序,因為小程序是基于微信來運行的。所以,你登錄的時候需要用到一個微信內部生成的js_code這個值。光是這一步就是一個深不見底的巨坑。
好吧,億分之一概率的情況下,你獲取了這個值,之后就是獲取search_key這個值,還有就是一個UNIX時間戳。
完事你就可以盡情的獲取你想要的數據了??????
少年,做人還是要穩(wěn)重點的。。。微信有一個訪問限制的系統(tǒng)。請求到一定的頻次,會提示操作頻繁的。所以你費好大勁完事之后,還是沒有什么太實際的結果。
網上有一個解決方案是這樣的,就是用lua語言配合觸動精靈寫一個操作微信的腳本,類似自動搶紅包那樣的。完事用這個腳本來自動輸入關鍵詞進行查詢,完事再使用抓包工具獲取這些請求內容。
關于使用抓包工具獲取請求內容不太清楚的親們,可以參考:https://www.jb51.net/article/177679.htm
先不說這種方案的成功率。咱們先來說說效率問題。難不成,你這樣做,微信就不會限制你的請求???
還有就是學習一門語言的各種成本。。。
所以,本人使用PHP結合fiddler抓包工具,設計了一個簡單,易學的抓取數據的方案。容我一一道來:
首先就是配置fiddler可以把抓取的數據保存到本地。
參考鏈接:https://www.jb51.net/article/177679.htm
這是用來獲取訪問令牌的,核心PHP代碼如下:
function get_search_key($path)
{
$file = fopen($path, "r");
$user=array();
$i=0;
while(! feof($file))
{
$user[$i]= mb_convert_encoding ( fgets($file), 'UTF-8','Unicode');
$i++;
}
fclose($file);
$user=array_filter($user);
foreach ($user as $item_u => $value_u) {
if(strstr($value_u,"search_key=")){
$temp[] = $value_u;
}
}
$end_url = end($temp);
$reg = "#openid=[a-zA-Z0-9]++_[a-zA-Z0-9]++search_key=\d++_\d++#isU";
preg_match_all($reg,$end_url,$time);
return $time[0][0];
}
輸入保存文件的地址,得到返回值,拿著這個返回值,來進行請求,就可以獲取你想要的數據了。
不過,這玩意也是有缺陷。首先就是配置手機連接電腦,關于這個,我后期會在評論里補充上。再來就是配置fiddler保存包到本地文件。還有就是需要手機訪問小程序之后程序才能運行成功。比較麻煩。
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php socket用法總結》、《php字符串(string)用法總結》、《PHP數學運算技巧總結》、《php面向對象程序設計入門教程》、《PHP數組(Array)操作技巧大全》、《PHP數據結構與算法教程》、《php程序設計算法總結》及《PHP網絡編程技巧總結》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- PHP+fiddler抓包采集微信文章閱讀數點贊數的思路詳解
- Fiddler如何抓取手機APP數據包
- fiddler抓包小技巧之自動保存抓包數據的實現方法分析【可根據需求過濾】
- Python如何爬取微信公眾號文章和評論(基于 Fiddler 抓包分析)
- 抓包工具Fiddler的使用方法詳解(Fiddler中文教程)
- Fiddler實現手機抓包之小白入門必看
- 利用Fiddler對手機進行抓包的實現方法
- PHP的cURL庫功能簡介 抓取網頁、POST數據及其他
- PHP中4種常用的抓取網絡數據方法
- php使用curl代理實現抓取數據的方法
- PHP的CURL方法curl_setopt()函數案例介紹(抓取網頁,POST數據)