爬取微信公众号文章2获取页面失败

虽然获取到了微信公众号文章的链接,但没法获取到包含文章内容的 html。

花了一个小时来研究怎么获取页面,最后还是失败了。

requests

首先按照一般思路,使用 requests 库来获取页面,但是获取到的却是不含有文章内容的一堆 js 代码和 css 代码,以及少量的没有内容的 html。

去查看 Ajax 请求,有 4 个请求,其中三个都是没有文章内容的 json,而第一个请求也是最可疑的一个,无法预览。

第一个请求的接口:

1
https://mp.weixin.qq.com/mp/appmsgreport?action=page_time&__biz=MzAwNjA3Nzg0MA==&uin=&key=&pass_ticket=&wxtoken=777&devicetype=&clientversion=&appmsg_token=&x5=0&f=json

这是以 POST 方式访问的接口,下面一大堆的 Form data,这其中甚至还有文章的标题!

也就是说在访问这个接口之前,就已经得知了文章的内容了吗?

selenium

我觉得模拟请求太过于复杂,于是尝试使用 selenium 来获取。

但是得到的内容和上文说的一样,并没有什么不同。非常奇怪。加了 60 秒的延时让它充分渲染也没用,问题不在这里。

教训

后来输出到文件才发现,内容并没有少,确确实实地获取到了文章内容,但是由于 print 出来的字符数有限制,无法在控制台显示完,才导致我以为获取失败。当个教训吧。

作者

憧憬少

发布于

2019-08-11

更新于

2019-08-11

许可协议