新版知乎反爬虫js逆向过程

大约是在2020年3月底左右,知乎的反爬虫开始升级,再也不能放个UA就肆无忌惮的爬取了,此次的爬虫升级主要是在请求头中增加了一些加密参数,如图,其中必不可少的参数是x-zse-86,x-ab-param参数可以不要,x-zse-81参数是因为滑动翻页才会出现,不过有种方式可以让它不出现也可以翻页。
啊啊啊啊啊啊在这里插入图片描述破解x-zse-86的过程记录如下:
1.全局搜索,定位加密参数所在位置
在这里插入图片描述2.找到参数,打断点![在这里插入图片描述](https://img-blog.csdnimg.cn/2020061919470689.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2hlX3Jhbmx5,size_16,color_FFFFFF,t_70在这里插入图片描述3.观察加密参数上下文传了什么,被哪个函数加密,加密了变成了什么
在这里插入图片描述在这里可以看到f.signature就是我们要找到参数,我们找到f所在函数继续打断点
在这里插入图片描述最后找到了这里其中f的形式为:"3_2.0+/api/v4/search_v3?t=general&q=python&correction=1&offset=0&limit=20&lc_idx=0&show_all_topics=0+https://www.zhihu.com/search?type=content&q=python+“AIBWd7QGcxGPTuF4P_hiRBjNjKKmH7mnibE=|1592557053"”

其中"AIBWd7QGcxGPTuF4P_hiRBjNjKKmH7mnibE=|1592557053"这一传是cookie中的d0c参数,前面部分我们可以根据搜索链接构造,最后的步骤就是找到F()函数和q()函数了
最终效果:
在这里插入图片描述

### 回答1: Python爬虫源代码,是指使用Python编写的用于抓取互联网信息的程序代码。知乎是一个知识问答社区,许多人想要在知乎上抓取数据,因此有许多人编写了Python爬虫源代码用于抓取知乎的内容。 为了编写一个能够抓取知乎内容的Python爬虫,首先需要导入相应的库,例如requests库用于发送HTTP请求、BeautifulSoup库用于解析HTML页面等。然后,需要编写一系列函数来实现抓取知乎内容的具体功能。 首先,需要编写一个发送HTTP请求的函数,用于获取页面的原始HTML代码。利用requests库发送GET请求获取知乎页面的HTML代码。 接下来,需要利用BeautifulSoup库解析HTML代码,提取出需要的数据。可以使用BeautifulSoup提供的各种方法来定位和提取特定的标签、类名或其他属性的内容,如问题的标题、问题的描述、回答的内容等。 然后,可以编写一个保存数据的函数,将抓取到的知乎内容存储到本地文件或数据库中,以便后续的数据处理和分析。 另外,还可以编写一个循环函数,用于自动翻页并抓取更多的数据。通过观察知乎页面的URL结构,可以发现一个规律,根据这个规律来修改URL,实现翻页的功能。 最后,可以编写一个主函数,用于调用各个函数,实现整个爬虫的流程控制。 总结起来,知乎Python爬虫源代码就是用Python编写的用于抓取知乎内容的程序代码。这些代码包括发送HTTP请求、解析HTML页面、提取数据、保存数据以及实现翻页等功能。编写一个高效、稳定的爬虫源代码需要对Python编程基础和相关库的使用有一定的掌握程度,同时还需要了解HTML的基本结构和知乎页面的规律。 ### 回答2: 知乎是一个知识分享社区,而Python爬虫是一种通过编写代码自动从网页上提取信息的技术。因此,知乎的Python爬虫源代码可以理解为使用Python编写的用于从知乎上获取信息的代码。 一般来说,编写知乎爬虫源代码需要以下步骤: 1. 导入所需的库:首先,我们需要导入Python的相应库,比如requests用于发送HTTP请求,BeautifulSoup用于解析网页等。 2. 发送HTTP请求获取网页内容:使用requests库发送HTTP请求,获取知乎网页的内容。 3. 解析网页内容:使用BeautifulSoup库解析网页内容,提取出我们需要的信息。可以通过查看网页源代码确定需要提取的信息所处的位置,并使用相应的标签和属性来进行定位和提取。 4. 存储提取的信息:将提取出的信息存储到合适的数据结构中,比如列表或字典,便于后续的处理和分析。 5. 处理分页:如果需要获取多页的信息,可以编写代码实现自动翻页,继续发送HTTP请求获取下一页的内容,并将提取出的信息追加到之前的数据结构中。 6. 数据持久化:将提取出的信息保存到文件或数据库中,以便后续的使用和分析。 需要注意的是,由于知乎爬虫有一定的限制,我们在编写知乎爬虫时需要遵守相关的法律法规和知乎的使用规则,避免对知乎服务器造成过大的负担或侵犯他人的隐私。同时,为了增加程序的稳定性和可靠性,我们还可以添加异常处理机制,防止因网络问题或网页结构变化导致的程序崩溃。 总之,知乎的Python爬虫源代码主要包括导入库、发送HTTP请求、解析网页内容、存储提取的信息、处理分页和数据持久化等步骤。通过编写这样的代码,我们可以方便地从知乎上获取所需的信息,并进行分析、研究和应用。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值