B站视频发布接口分析
项目地址:https://gitee.com/nbody1996/bilibili_video_uploader
视频地址:https://www.bilibili.com/video/BV1qt4y1v76u/
获取登录Cookies
请求要带着登录成功后关键Cookies,才能被B站后台认为是已登录的状态。
研究发现,以下两个是必要的:
- SESSDATA(session会话cookies, 相当于登录凭证)
- bili_jct(防CSRF攻击)
这两个都能在浏览器开发者工具(F12)中查看到,比如在谷歌浏览器中:
然后将这两个值复制下来,在接下来的请求中cookies带上这两个值即可保持登录状态
解决方案:
-
可用
requests.Session.cookies = requests.utils.cookiejar_from_dict
设置Cookies,将在以后请求会话中保持 -
可用
requests.Session.headers = {'User-Agent':'???'}
设置UA,将在以后请求会话中保持
preupload预上传
请求方法: GET
请求接口: https://member.bilibili.com/preupload
请求体:
响应体:
请求体解决方案:
-
name参数可由
os.path.basename
或pathlib.Path.name属性
获得 -
size参数可由
os.path.getsize
或pathlib.Path.stat().st_size
获得
step1 准备上传视频
请求方法: POST
请求接口: https://upos-sz-upcdnbda2.bilivideo.com/[upos_uri]
替换上面[upos_uri]
为preupload预上传接口
响应体中upos_uri
的upos://
的后面部份,比如https://upos-sz-upcdnbda2.bilivideo.com/ugcboss/m201010a23h35mci3cejzh2xe4a6gwq1.mp4
请求头:
请求体:
响应体:
step2 分批上传视频
重难点
请求方法: PUT
请求接口: 同step1接口
请求头: 同step1接口
请求体(分两个部份):
请求体解决方案:
params参数通过requests.put的params
参数传递,payload
通过requests.put的data
参数传递
-
chunks
总批次根据preupload响应体中chunk_size
参数计算得出,通过math.ceil(filesize/chunk_size)
向上取整。得到chunks
后,在循环中改变partNumber
、chunk
两者 -
内置函数
open
获得视频文件IO流。read(size=chunk_size)
方法获得指定大小的视频字节,并通过内置函数len
获得当前批次字节数size
参数。tell
方法获取当前字节位置,对应start
与end
参数 -
在循环中改变
partNumber
、chunk
、chunks
、size
、start
和end
参数 -
将
read
读出的字节通过requests.put的data
参数传递过去
step3 通知上传完毕
请求方法: POST
请求接口: 同step1接口
请求头: 同step1接口
请求体(分两个部份):
PS: 上图没有用框框住的参数,都是固定写死
请求体解决方案:
json形式的请求体可以用requests.post的json
参数传递
轮询获取视频封面
请求方法: GET
请求接口: https://member.bilibili.com/x/web/archive/recovers?fns=[bfilename]
注意把[bfilename]
替换成在B站的视频文件名
响应体:
解决方案: 因为要等待B站后端处理好封面图片,所以这一步需要隔一段时间就访问一下该接口,直到响应体的data
字段不是空列表时结束轮询
选择推荐分区
请求方法: GET
请求接口: https://member.bilibili.com/x/web/archive/typeid
请求体:
PS:
-
groupid
不清楚干嘛用的, 目前遇到可以固定是0或1 -
vfea
不清楚干嘛用的, 空字符串即可
响应体:
选择推荐标签
请求方法: GET
请求接口: https://member.bilibili.com/x/web/archive/typeid
请求体:
响应体:
PS: 可以用列表推导式将标签字符串存于列表中,再用字符串join
方法用英文逗号
拼接
预发布
请求方法: GET
请求接口: https://member.bilibili.com/x/geetest/pre/add
PS: 没啥好讲的, 直接get
这个链接,它的响应体也没什么有用的东西
发布视频
经过前面的"过五关斩六将",终于到了最后一步了
请求方法: POST
请求接口: https://member.bilibili.com/x/vu/web/add?csrf=[bili_jct]
注意替换链接中csrf
参数为bili_jct
(一开始需要的两个Cookies的中其一)
请求体(JSON):
自制类型的视频请求体与上图有些许差别:
- 因为source是只针对于转载类型视频的,所以自制类型视频不需要携带该参数
- 新增interactive参数,取值0或1,貌似是跟允许观众投稿字幕有关
- 新增no_reprint参数,取值0或1,貌似是跟自制声明有关
- 最重要的是声明版权,改变copyright为1即可
完整代码
Talk is cheap, Show me the code
戳它: https://gitee.com/nbodyfun/bilibili_video_uploader/raw/master/bilibili_up.py
到此这篇关于Biblibili视频投稿接口分析并以Python实现自动投稿功能的文章就介绍到这了,更多相关Python实现自动投稿内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://nbodyfun.blog.csdn.net/article/details/109045413