A backup tool for renren.com
特别说明:
2024 年 4 月,人人网页版彻底不可用,本工具也不再能模拟网页操作备份任何内容
2022 年 1 月更新,支持新接口,可抓取本人信息,不支持抓取非本人信息。Windows 下单独运行版本更新到 2.x 序列
2021 年 5 月人人网 Web 端全面改版,之前的页面入口逻辑都不存在,本工具不可用
2020 年 11 月开始人人网的状态功能出现异常,无法抓取,使用时请去掉-s
参数跳过状态的抓取
2019 年 8 月开始人人网的日志功能出现异常,无法抓取,使用时请去掉-b
参数跳过日志的抓取
- 在 https://github.com/whusnoopy/renrenBackup/releases/latest 发布页面下载最新的
renrenBackup_x.x.zip
压缩文件,解压到一个单独的目录 - 在命令提示符进入该目录,执行
renrenBackup.exe fetch -e email -p password -g -a
来抓取账号为email
密码是password
的用户信息(详细参数可见下方 Python 环境运行方式) - 抓取后,在命令提示符下执行
renrenBackup.exe runserver
后,可以在浏览器里打开 http://localhost:5000 来查看抓取后的展示 - 抓取后,在命令提示符下执行
renrenBackup.exe export -f backup.tar
,可以生成backup.tar
这个打包文件,解压后无需任何环境直接用浏览器打开index.html
即可浏览备份好的信息
注意:目前的版本并未经过严格测试和兼容性确认,只在 Windows 10 x64 21H2 版本上简单确认可用,其他系统(Linux/macOS)或版本(非 Win10x64)都可能无法运行,欢迎协助更新
理论上 Python 3.6+ 都可以用 (我是在 Windows 10 x64 21H2 + Python 3.10.2 的环境下测试的)
使用 virtualenv 构建运行所需虚拟环境
virtualenv env
source env/bin/activate
pip install -r requirements.txt
直接运行 python manage.py fetch
即可,相关参数见下,不输入用户名密码是不会抓取的,不带各种抓取参数就是只登陆不抓取
-e email
用户名(邮箱)-p password
密码-s
状态-g
留言板-a
相册-b
日志-u
要抓的人的人人 uid(仅能抓取当前登录账户可见的内容)-r
强制更新已抓取用户的统计信息
# 查看详细的命令参数
$ python manage.py fetch --help
usage: manage.py fetch [-?] [-e EMAIL] [-p PASSWORD] [-s] [-g] [-a] [-b] [-r]
[-u UID]
optional arguments:
-?, --help show this help message and exit
-e EMAIL, --email EMAIL
-p PASSWORD, --password PASSWORD
-s, --status
-g, --gossip
-a, --album
-b, --blog
-r, --refresh_count
-u UID, --uid UID
# 抓取自己的所有信息
$ python manage.py fetch -e email@renren.com -p passwordAtRenren -s -g -a -b
# 指定抓取某人的留言板
$ python manage.py fetch -e email@renren.com -p passwordAtRenren -g -u 30314
# 强制更新某人的抓取统计信息
$ python manage.py fetch -e email@renren.com -p passwordAtRenren -u 30314 -r
如果遇到要登录验证码的情况,在终端提示时输入自动打开的图片上的四个字母数字即可。如果没有自动打开验证码图片,可到项目的 /static/icode.jpg
找到,自行打开并输入验证码
直接运行如下命令,即可在本机浏览器打开 http://localhost:5000 看到展示
python manage.py runserver
将抓取的页面和静态文件统一打包,将打包文件解压后可以不启动 flask 也能查看
python manage.py export -f backup.tar
目前在 Windows 平台下使用 pyinstaller + pywin32 来做版本发布,希望给没有 Python 环境的朋友提供帮助
下述操作均在 Windows 的命令提示符(cmd)下完成,PowerShell 和 WSL 可能出现奇怪的问题(我还不确定问题原因)
# 安装依赖
pip install pyinstaller pywin32
# 打包发布,会在 dist 目录下生成 renrenBackup.exe,并把 static 和 templates 初始目录也放到 dist 下
python manage.py release
执行命令后将 dist
目录单独打成一个压缩包就可以发布了
- 纯静态输出,不用启 flask 也能查看(把评论点赞数据也输出到页面,js 只控制是否展示)
- 备份打包
- 可以抓别人的记录
- 同时展示多人记录
- 参数交互输入,更好满足非 Python 环境下的可用性
- 强制重抓之前抓挂的图(还挂就替换成默认图)
- 断点续传,抓到一半挂了后,重启跳过已抓取的内容(或根据 DB 已有数据来优化抓取量)#13
- 用 Python 的日志系统替代 print 输出
- 纯动态输出,学习用 Vue.js
- 搜索功能 #21