xhs_crawler/README.md

138 lines
5.7 KiB
Markdown
Raw Normal View History

2023-06-28 13:58:36 +00:00
> **免责声明:**
2023-06-28 13:58:36 +00:00
>本仓库的所有内容仅供学习和参考之用,禁止用于商业用途。任何人或组织不得将本仓库的内容用于非法用途或侵犯他人合法权益。本仓库所涉及的爬虫技术仅用于学习和研究,不得用于对其他平台进行大规模爬虫或其他非法行为。对于因使用本仓库内容而引起的任何法律责任,本仓库不承担任何责任。使用本仓库的内容即表示您同意本免责声明的所有条款和条件。
# 仓库描述
2023-06-28 13:58:36 +00:00
**小红书爬虫****抖音爬虫** ...。
目前能稳定抓取小红书的视频、图片、评论、点赞、转发等信息,抖音的视频、图片、评论、点赞等信息。
2023-06-28 13:58:36 +00:00
原理:利用[playwright](https://playwright.dev/)搭桥保留登录成功后的上下文浏览器环境通过执行JS表达式获取一些加密参数
通过使用此方式免去了复现核心加密JS代码逆向难度大大降低。
2023-06-28 13:58:36 +00:00
## 已实现
- [x] 小红书登录二维码、手机号、cookies
- [x] 小红书Sign请求签名
- [x] 抖音Sign请求签名
- [x] 代理池实现(手机号+IP
- [x] 并发执行爬虫请求
- [x] 抖音登录二维码、手机号、cookies
- [x] 抖音滑块模拟滑动实现准确率不太OK
2023-07-15 14:25:56 +00:00
- [x] 支持登录成功后的上下文浏览器环境保留
2023-08-16 11:49:41 +00:00
- [x] 数据保存到CSV中默认
- [x] 数据保持到数据库中(可选)
2023-06-28 13:58:36 +00:00
## 使用方法
1. 安装依赖库
2023-07-30 12:43:02 +00:00
```shell
pip install -r requirements.txt
```
2. 安装playwright浏览器驱动
2023-07-30 12:43:02 +00:00
```shell
playwright install
```
3. 是否保存数据到DB中
如果选择开启,则需要配置数据库连接信息,`config/db_config.py` 中的 `IS_SAVED_DATABASED`和`RELATION_DB_URL` 变量。然后执行以下命令初始化数据库信息,生成相关的数据库表结构:
```shell
python db.py
```
4. 运行爬虫程序
```shell
python main.py --platform xhs --lt qrcode
```
5. 打开对应APP扫二维码登录
2023-08-16 11:49:41 +00:00
6. 等待爬虫程序执行完毕,数据会保存到 `data/xhs` 目录下
2023-06-28 13:58:36 +00:00
## 项目代码结构
```
MediaCrawler
├── base
│ ├── base_crawler.py # 项目的抽象类
│ └── proxy_account_pool.py # 账号与IP代理池
2023-08-16 11:49:41 +00:00
├── browser_data # 浏览器数据目录
2023-06-28 13:58:36 +00:00
├── config
2023-07-30 12:43:02 +00:00
│ ├── account_config.py # 账号代理池配置
│ ├── base_config.py # 基础配置
│ └── db_config.py # 数据库配置
2023-08-16 11:49:41 +00:00
├── data # 数据保存目录
2023-06-28 13:58:36 +00:00
├── libs
│ ├── douyin.js # 抖音Sign函数
│ └── stealth.min.js # 去除浏览器自动化特征的JS
2023-06-28 13:58:36 +00:00
├── media_platform
│ ├── douyin # 抖音crawler实现
│ │ ├── client.py # httpx 请求封装
│ │ ├── core.py # 核心实现
│ │ ├── exception.py # 异常处理
│ │ ├── field.py # 字段定义
│ │ └── login.py # 登录实现
│ └── xiaohongshu # 小红书crawler实现
│ ├── client.py # API httpx 请求封装
│ ├── core.py # 核心实现
│ ├── exception.py # 异常处理
│ ├── field.py # 字段定义
│ ├── help.py # 辅助函数
│ └── login.py # 登录实现
2023-06-28 13:58:36 +00:00
├── modles
│ ├── douyin.py # 抖音数据模型
│ └── xiaohongshu.py # 小红书数据模型
2023-06-28 13:58:36 +00:00
├── tools
│ └── utils.py # 工具函数
├── main.py # 程序入口
└── recv_sms_notification.py # 短信转发器的HTTP SERVER接口
2023-06-28 13:58:36 +00:00
```
## 数据持久化
2023-06-28 13:58:36 +00:00
![数据持久化](https://s2.loli.net/2023/07/24/ZTcGWz8jPAy7b5M.png)
2023-06-28 13:58:36 +00:00
## 支持一下
- 如果该项目对你有帮助star一下 ❤️❤️❤️
[![Star History Chart](https://api.star-history.com/svg?repos=NanmiCoder/MediaCrawler&type=Date)](https://star-history.com/#NanmiCoder/MediaCrawler&Date)
## 关于手机号+验证码登录的说明
2023-06-28 13:58:36 +00:00
当在浏览器模拟人为发起手机号登录请求时,使用短信转发软件将验证码发送至爬虫端回填,完成自动登录
准备工作:
2023-06-28 13:58:36 +00:00
- 安卓机1台IOS没去研究理论上监控短信也是可行的
- 安装短信转发软件 [参考仓库](https://github.com/pppscn/SmsForwarder)
- 转发软件中配置WEBHOOK相关的信息主要分为 消息模板请查看本项目中的recv_sms_notification.py、一个能push短信通知的API地址
2023-06-28 13:58:36 +00:00
- push的API地址一般是需要绑定一个域名的当然也可以是内网的IP地址我用的是内网穿透方式会有一个免费的域名绑定到内网的web
server内网穿透工具 [ngrok](https://ngrok.com/docs/)
- 安装redis并设置一个密码 [redis安装](https://www.cnblogs.com/hunanzp/p/12304622.html)
- 执行 `python recv_sms_notification.py` 等待短信转发器发送HTTP通知
- 执行手机号登录的爬虫程序 `python main.py --platform xhs --lt phone`
备注:
2023-06-25 14:01:38 +00:00
2023-06-28 13:58:36 +00:00
- 小红书这边一个手机号一天只能发10条短信悠着点目前在发验证码时还未触发滑块验证估计多了之后也会有~
- 短信转发软件会不会监控自己手机上其他短信内容?(理论上应该不会,因为[短信转发仓库](https://github.com/pppscn/SmsForwarder)
2023-06-28 13:58:36 +00:00
star还是蛮多的
2023-06-25 14:01:38 +00:00
## 参考
2023-06-28 13:58:36 +00:00
- xhs客户端 [ReaJason的xhs仓库](https://github.com/ReaJason/xhs)
- 短信转发 [参考仓库](https://github.com/pppscn/SmsForwarder)
2023-06-28 13:58:36 +00:00
- 内网穿透工具 [ngrok](https://ngrok.com/docs/)