商务服务
11.3 mitmdump 爬取 “得到” App 电子书信息
2024-12-16 09:49

“得到” App 是罗辑思维出品的一款碎片时间学习的 App,其官方网站为 https://www.igetget.com,App 内有很多学习资源。不过 “得到” App 没有对应的网页版,所以信息必须要通过 App 才可以获取。这次我们通过抓取其 App 来练习 mitmdump 的用法。

我们的爬取目标是 App 内电子书版块的电子书信息,并将信息保存到 MongoDB,如图 11-30 所示。

我们要把图书的名称、简介、封面、价格爬取下来,不过这次爬取的侧重点还是了解 mitmdump 工具的用法,所以暂不涉及自动化爬取,App 的操作还是手动进行。mitmdump 负责捕捉响应并将数据提取保存。

请确保已经正确安装好了 mitmproxy 和 mitmdump,手机和 PC 处于同一个局域网下,同时配置好了 mitmproxy 的 CA 证书,安装好 MongoDB 并运行其服务,安装 PyMongo 库,具体的配置可以参考第 1 章的说明。

首先探寻一下当前页面的 URL 和返回内容,我们编写一个脚本如下所示:


这里只输出了请求的 URL 和响应的 Body 内容,也就是请求链接和响应内容这两个最关键的部分。脚本保存名称为 script.py。

接下来运行 mitmdump,命令如下所示:


打开 “得到” App 的电子书页面,便可以看到 PC 端控制台有相应输出。接着滑动页面加载更多电子书,控制台新出现的输出内容就是 App 发出的新的加载请求,包含了下一页的电子书内容。控制台输出结果示例如图 11-31 所示。

图 11-31 控制台输出

可以看到 URL 为 https://dedao.igetget.com/v3/discover/bookList 的接口,其后面还加了一个 sign 参数。通过 URL 的名称,可以确定这就是获取电子书列表的接口。在 URL 的下方输出的是响应内容,是一个 JSON 格式的字符串,我们将它格式化,如图 11-32 所示。

图 11-32 格式化结果

格式化后的内容包含一个 c 字段、一个 list 字段,list 的每个元素都包含价格、标题、描述等内容。第一个返回结果是电子书《情人》,而此时 App 的内容也是这本电子书,描述的内容和价格也是完全匹配的,App 页面如图 11-33 所示。

图 11-33 APP 页面

这就说明当前接口就是获取电子书信息的接口,我们只需要从这个接口来获取内容就好了。然后解析返回结果,将结果保存到数据库。

接下来我们需要对接口做过滤限制,抓取如上分析的接口,再提取结果中的对应字段。

这里,我们修改脚本如下所示:


重新滑动电子书页面,在 PC 端控制台观察输出,如图 11-34 所示。

图 11-34 控制台输出

现在输出了图书的全部信息,一本图书信息对应一条 JSON 格式的数据。

接下来我们需要提取信息,再把信息保存到数据库中。方便起见,我们选择 MongoDB 数据库。

脚本还可以增加提取信息和保存信息的部分,修改代码如下所示:


重新滑动页面,控制台便会输出信息,如图 11-35 所示。

图 11-35 控制台输出

现在输出的每一条内容都是经过提取之后的内容,包含了电子书的标题、封面、描述、价格信息。

最开始我们声明了 MongoDB 的数据库连接,提取出信息之后调用该对象的 insert() 方法将数据插入到数据库即可。

滑动几页,发现所有图书信息都被保存到 MongoDB 中,如图 11-36 所示。

目前为止,我们利用一个非常简单的脚本把 “得到” App 的电子书信息保存下来。

本节的代码地址是:https://github.com/Python3WebSpider/IGetGet。

    以上就是本篇文章【11.3 mitmdump 爬取 “得到” App 电子书信息】的全部内容了,欢迎阅览 ! 文章地址:http://www78564.xrbh.cn/news/30314.html 
     文章      相关文章      动态      同类文章      热门文章      栏目首页      网站地图      返回首页 迅博思语移动站 http://www78564.xrbh.cn/mobile/ , 查看更多   
最新文章
太原大眼熊猫眼科教你分辨真假近视
暑假余额告急!孩子们放飞自我的同时,电子屏幕“全天候陪伴”、沙发上的沉浸式阅读、户外活动的严重缺席……这些“放纵”的代价
蓝盾链条 _520摩托车链条
浙江蓝盾工贸有限公司主要生产蓝盾、盾久牌各种碳钢、不锈钢传动用精密滚子链、套筒链、输送链、板式链以及各种领域所应用的各种
OpenAI申请GPT-5中国商标遇挫,相关申请均被驳回
8 月 11 日消息,OpenAI 上周正式发布新一代人工智能模型 GPT-5,该模型已在中国提交商标申请,国际分类涵盖科学仪器、网站服务
军事晚报AI速递:今日军事热点一览 丨2025年8月14日
  军事领域动态复杂,事件可能迅速改变全球安全格局。我们整理了今日最重要的军事新闻,包括关键行动和政策变化,让您清晰把握
Skywork Deep Research Agent重磅升级!带来更多模态、更高质量和更高效的体验
8月11日,昆仑万维SkyWork AI技术发布周正式启动。8月11日至8月15日,我们每天发布一款新模型,连续五天,覆盖多模态AI核心场景
回收燕京八景茅台酒瓶 上门回收燕京八景空瓶
回收燕京八景茅台酒瓶 上门回收燕京八景空瓶另外给大家附上茅台酒瓶大约价格800元--9000元;回收价格不等;如有其他生肖或者没有
施耐德NSX-400H NSX-400H塑壳断路器说明书
施耐德NSX-400H】NSX-400H塑壳断路器说明书】品牌:施耐德电气. 型号:NSX 塑壳断路器 乐清市森发电器厂主要经营品牌有:常熟开
专卖 日本宝理 PBT 209AW 流动性好
209AW PBT 日本宝理 总代理 深圳209AW PBT 日本宝理 总代理 深圳209AW PBT 日本宝理 总代理 深圳209AW PBT 日本宝理 总代理 深圳
第七届“中华朗读者”全国总展演在西安圆满落幕
2025年8月4日,第七届“中华朗读者”青少年语言艺术展演全国总展演在古都西安圆满举办。本届展演以“展教融媒”为核心理念,依托
蛇年茅台酒瓶回收价值回收空瓶2025全国上门
蛇年茅台酒瓶回收价值回收空瓶2025全国上门 2024 年茅台酒:单瓶回收 2100 元,原箱(6 瓶装)13200 元2023 年茅台酒:单瓶回收