脚本专栏 发布日期:2025/1/10 浏览次数:1
B站视频发布接口分析
项目地址:https://gitee.com/nbody1996/bilibili_video_uploader
视频地址:https://www.bilibili.com/video/BV1qt4y1v76u/
请求要带着登录成功后关键Cookies,才能被B站后台认为是已登录的状态。
研究发现,以下两个是必要的:
这两个都能在浏览器开发者工具(F12)中查看到,比如在谷歌浏览器中:
然后将这两个值复制下来,在接下来的请求中cookies带上这两个值即可保持登录状态
解决方案:
requests.Session.cookies = requests.utils.cookiejar_from_dict
设置Cookies,将在以后请求会话中保持requests.Session.headers = {'User-Agent':'"text-align: center">
响应体:
请求体解决方案:
- 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"text-align: center">
解决方案: 因为要等待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"text-align: center">
自制类型的视频请求体与上图有些许差别:
- 因为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