一篇文章教会你用Python抓取抖音app热点数据
今天给大家分享一篇简单的安卓app数据分析及抓取方法。以抖音为例,我们想要抓取抖音的热点榜数据。
要知道,这个数据是没有网页版的,只能从手机端下手。 首先我们要安装charles抓包APP数据,它是一款收费的抓包修改工具,易上手,数据请求容易控制,修改简单,抓取数据的开始暂停方便等优势,网上也有汉化版,下载地址为http://www.zdfans.com/html/42074.html,一路默认安装就ok了。 安装完成后要设置代理,依次点击代理——代理设置。
然后在手机端设置代理,如下图所示:
在保证手机和电脑在同一局域网的情况下,代理服务器主机名设为电脑的ip地址,端口设为8888。 最后在电脑端和手机端分别安装证书。 电脑端安装方法:依次点击帮助——ssl代理——安装charles root证书 ,按下图进行安装。
手机端安装方式:帮助——ssl代理——在移动设备或远程浏览器上安装charles root证书。 再在模拟器浏览器中输入chls.pro/ssl,会自动下载手机端证书 最后再手机端依次点击设置——安全——从SD卡安装。
为证书命名,点击确认就安装成功了。 打开charles,然后打开抖音app的热点榜界面,在charles很容易就找到了数据接口,一次就返回了50条数据,如下图所示。
它的url信息如下图所示。
此接口只能返回这一时刻的热点数据,要想返回新的数据,就要变换参数信息,但是App端的数据接口参数都比较复杂,这里我们不再深入分析。 为了解决这一问题,我们可以用appium定时模拟操控手机,然后用mitmproxy把数据拦截下来(关于appium、mitmproxy的简介与安装网上有很多教程,这里不再赘述) Appium脚本如下图所示:
这个自动化测试脚本比较简单,主要是重复获取热点最新信息。 Mitmproxy脚本如图:
有4点需要注意的地方:
1.用mitmproxy抓包前,先把手机代理ip端口设置为8080,设置方法同上; 2.要想在此脚本运行外置函数,必须加上前两行,要不然会出错; 3.脚本中if url in flow.request.url为数据流判断条件,如果url在该数据流的url请求数据中,则判断该数据为抖音app热点数据; 4.最后在脚本所在路径运行以下程序:
最后再运行appium自动化测试脚本,就大功告成了。
如果需要本文的代码,请在后台回复“抖音”二字,觉得不错,记得给个star噢~
看完本文有收获?请转发分享给更多的人
IT共享之家
入群请在微信后台回复【入群】

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Java 学习杂记
Java 杂记 mybatis 的查询 mybatis 查询没有数据的时候,会返回什么? 返回类是基本数据类型的包装类型和对象,返回为空 null 返回List或Map时,返回结果时是为空的集合 返回结果是基本数据类型时,没有数据时会抛出异常 Guava 强大的集合工具Lists Guava的Lists类中提供了许多实用的方法和静态函数,可以帮助我们优雅的编码。 集合分区方法 - partition() 集合转换方法 - transform() 获取笛卡尔积方法 - cartesianProduct() Lists.newLinkedList() Lists.newArrayList();参考文档:Guava - 强大的集合工具Lists maven相关 maven 依赖问题 项目使用maven管理jar包,很容易因为各种原因(网速慢、断网)导致jar包下载不下来,出现很多.lastUpdated文件。这些不完全下载的包,会导致maven不会去远程下载,需要到仓库的目录下去清除。 maven项目pom.xml中scope类型 scope的分类 compile:默认值 他表示被依赖项目需...
- 下一篇
xJavaFxTool 0.2.1 发布,优化界面布局
基于 JavaFx 搭建的实用小工具集合xJavaFxTool更新至 0.2.1 版本,此版本优化了界面布局,感谢 捏造的信仰 积极参与项目贡献代码! 此次更新中新增内容如下: 添加吐槽页面 添加设置页面 添加小程序码生成工具(由 三叔 贡献代码) 此次更新中优化的内容如下: 优化部分页面布局 优化插件管理页面 优化对话框样式
相关文章
文章评论
共有0条评论来说两句吧...