118 KiB
用户空间相关
主页
置顶视频
查询用户置顶视频
请求方式:GET
粉丝在其主页上可见
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
vmid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 53016:没有置顶视频 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | obj | 信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
aid | num | 稿件avid | |
videos | num | 视频分P总数 | 默认为1 |
tid | num | 分区tid | |
tname | str | 子分区名称 | |
copyright | num | 是否转载 | 1:原创 2:转载 |
pic | str | 视频封面图片url | |
title | str | 稿件标题 | |
pubdate | num | 稿件发布时间 | 时间戳 |
ctime | num | 用户提交稿件的时间 | 时间戳 |
desc | str | 视频简介 | |
state | num | 视频状态 | 略,见获取视频详细信息(web端)中的state 备注 |
attribute | num | 稿件属性位配置 | 略,见获取视频详细信息(web端)中的attribute 备注 |
duration | num | 视频总计持续时长(所有分P) | 单位为秒 |
rights | obj | 视频属性标志 | 略,见获取视频详细信息(web端)中的rights 对象 |
owner | obj | 视频UP主信息 | 略,见获取视频详细信息(web端)中的owner 对象 |
stat | obj | 视频状态数 | 略,见获取视频详细信息(web端)中的stat 对象 |
dynamic | str | 视频同步发布的的动态的文字内容 | 无为空 |
cid | num | 视频1P cid | |
dimension | obj | 视频1P分辨率 | 略,见获取视频详细信息(web端)中的dimension 对象 |
bvid | str | 稿件bvid | |
reason | str | 置顶视频备注 | |
inter_video | bool | 是否为合作视频 | false:否 true:是 |
示例:
查询用户mid=23215368
的置顶视频
curl -G 'https://api.bilibili.com/x/space/top/arc' \
--data-urlencode 'vmid=23215368'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"aid": 37896701,
"videos": 1,
"tid": 28,
"tname": "原创音乐",
"copyright": 1,
"pic": "http://i2.hdslb.com/bfs/archive/cc9e72822d68fffdd0406144f1b5348a13c89652.jpg",
"title": "燃烧吧!铃声!把主流手机铃声编成一首曲子",
"pubdate": 1544469671,
"ctime": 1544469671,
"desc": "各品牌的手机铃声大合奏,毫无违和感~",
"state": 0,
"attribute": 16768,
"duration": 208,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 1,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 23215368,
"name": "Wayjon冰冰酱",
"face": "http://i2.hdslb.com/bfs/face/7c9715f1768191137eb7ebf91918ca0f99532012.jpg"
},
"stat": {
"aid": 37896701,
"view": 1058237,
"danmaku": 16821,
"reply": 3725,
"favorite": 76888,
"coin": 100694,
"share": 17091,
"now_rank": 0,
"his_rank": 0,
"like": 90521,
"dislike": 0
},
"dynamic": "#编曲##FL##纯音乐#",
"cid": 66621209,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV18t411q7zz",
"reason": "",
"inter_video": false
}
}
设置置顶视频
请求方式:POST
认证方式:Cookie(SESSDATA)
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
aid | num | 置顶目标稿件avid | 必要(可选) | avid与bvid任选一个 |
bvid | str | 置顶目标稿件bvid | 必要(可选) | avid与bvid任选一个 |
reason | str | 置顶视频备注 | 非必要 | 置顶备注最大40字符 默认为空 |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -304:未修改 -400:请求错误 53014:稿件已失效 53015:备注过长 53017:置顶非自己的稿件 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
置顶视频av98948772
/BV1n741127LD
avid方式:
curl 'https://api.bilibili.com/x/space/top/arc/set' \
--data-urlencode 'aid=98948772' \
-b 'SESSDATA=xxx'
bvid方式:
curl 'https://api.bilibili.com/x/space/top/arc/set' \
--data-urlencode 'bvid=BV1n741127LD' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
取消置顶视频
请求方式:POST
认证方式:Cookie(SESSDATA)
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误(重复取消) |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
curl 'https://api.bilibili.com/x/space/top/arc/cancel' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
代表作视频
查询用户代表作视频列表
请求方式:GET
新访客在其主页上可见
最多可以设置3个
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
vmid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | array | 代表作列表 |
data
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 代表作1 | 无则为空 |
1 | obj | 代表作2 | 无则为空 |
2 | obj | 代表作3 | 无则为空 最多设置3个 |
data
数组中的对象:
同查询用户置顶视频中的data
对象
示例:
查询用户mid=23215368
的代表作视频列表
curl -G 'https://api.bilibili.com/x/space/masterpiece' \
--data-urlencode 'vmid=23215368'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": [{
"aid": 37896701,
"videos": 1,
"tid": 28,
"tname": "原创音乐",
"copyright": 1,
"pic": "http://i2.hdslb.com/bfs/archive/cc9e72822d68fffdd0406144f1b5348a13c89652.jpg",
"title": "燃烧吧!铃声!把主流手机铃声编成一首曲子",
"pubdate": 1544469671,
"ctime": 1544469671,
"desc": "各品牌的手机铃声大合奏,毫无违和感~",
"state": 0,
"attribute": 16768,
"duration": 208,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 1,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 23215368,
"name": "Wayjon冰冰酱",
"face": "http://i2.hdslb.com/bfs/face/7c9715f1768191137eb7ebf91918ca0f99532012.jpg"
},
"stat": {
"aid": 37896701,
"view": 1058241,
"danmaku": 16821,
"reply": 3725,
"favorite": 76888,
"coin": 100694,
"share": 17091,
"now_rank": 0,
"his_rank": 0,
"like": 90521,
"dislike": 0
},
"dynamic": "#编曲##FL##纯音乐#",
"cid": 66621209,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV18t411q7zz",
"reason": "",
"inter_video": false
}, {
"aid": 39596658,
"videos": 1,
"tid": 21,
"tname": "日常",
"copyright": 1,
"pic": "http://i2.hdslb.com/bfs/archive/431e51d0e40e3461e1c1b0f59c755ae8843b1adb.jpg",
"title": "MY2018 - 纪念我的2018年",
"pubdate": 1546328392,
"ctime": 1546328392,
"desc": "",
"state": 0,
"attribute": 16768,
"duration": 239,
"mission_id": 10996,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 1,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 23215368,
"name": "Wayjon冰冰酱",
"face": "http://i2.hdslb.com/bfs/face/7c9715f1768191137eb7ebf91918ca0f99532012.jpg"
},
"stat": {
"aid": 39596658,
"view": 1518,
"danmaku": 16,
"reply": 40,
"favorite": 22,
"coin": 60,
"share": 9,
"now_rank": 0,
"his_rank": 0,
"like": 112,
"dislike": 0
},
"dynamic": "#vlog##记录##生活记录#",
"cid": 69561078,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV1Jt411B7La",
"reason": "",
"inter_video": false
}, {
"aid": 44721369,
"videos": 1,
"tid": 28,
"tname": "原创音乐",
"copyright": 1,
"pic": "http://i0.hdslb.com/bfs/archive/9887797402599c42f74a7624f3db4a92a0ebf465.jpg",
"title": "【铃声串烧系列】华米两开花;中华有为,国之荣耀!把主流手机铃声编成一首曲子",
"pubdate": 1551128445,
"ctime": 1551128445,
"desc": "把主流手机铃声编成一首曲子,这一版用华为的铃声作为主旋律,毫无违和感~伴随着2019mwc的开幕,希望国产厂商能获得全世界的目光,并且将属于中国人的科技自信传递到全世界!",
"state": 0,
"attribute": 16768,
"duration": 174,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 1,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 23215368,
"name": "Wayjon冰冰酱",
"face": "http://i2.hdslb.com/bfs/face/7c9715f1768191137eb7ebf91918ca0f99532012.jpg"
},
"stat": {
"aid": 44721369,
"view": 306757,
"danmaku": 7713,
"reply": 1520,
"favorite": 17216,
"coin": 16489,
"share": 2917,
"now_rank": 0,
"his_rank": 0,
"like": 21439,
"dislike": 0
},
"dynamic": "#铃声##纯音乐##音乐#【铃声串烧】Mix Ringtones!船新的版本来啦!这一版用华为的铃声作为主旋律,毫无违和感~伴随着2019mwc的开幕,希望国产厂商能获得全世界的目光,并且将属于中国人的科技自信传递到全世界!",
"cid": 78290138,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV1vb411879C",
"reason": "",
"inter_video": false
}]
}
添加代表作视频
请求方式:POST
认证方式:Cookie(SESSDATA)
代表作上限为3个稿件
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
aid | num | 置顶目标稿件avid | 必要(可选) | avid与bvid任选一个 |
bvid | str | 置顶目标稿件bvid | 必要(可选) | avid与bvid任选一个 |
reason | str | 代表作备注 | 非必要 | 置顶备注最大40字符 默认为空 |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 53014:稿件已失效 53015:备注过长 53017:置顶非自己的稿件 53019:达到上限 53020:已经存在该稿件 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
添加视频av94916552
/BV1ZE411K7ux
到代表作列表
avid方式:
curl 'https://api.bilibili.com/x/space/masterpiece/add' \
--data-urlencode 'aid=94916552' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
bvid方式:
curl 'https://api.bilibili.com/x/space/masterpiece/add' \
--data-urlencode 'bvid=BV1ZE411K7ux' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
删除代表作视频
请求方式:POST
认证方式:Cookie(SESSDATA)
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
aid | num | 要删除的目标稿件avid | 必要(可选) | avid与bvid任选一个 |
bvid | str | 要删除的目标稿件bvid | 必要(可选) | avid与bvid任选一个 |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 53021:置顶列表中没有该视频 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | 作用尚不明确 |
示例:
删除置顶视频av59765630
/BV1Yt41137T6
avid方式:
curl 'https://api.bilibili.com/x/space/masterpiece/cancel' \
--data-urlencode 'aid=59765630' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
bvid方式:
curl 'https://api.bilibili.com/x/space/masterpiece/cancel' \
--data-urlencode 'bvid=BV1Yt41137T6' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
个人TAG
查看用户个人TAG
请求方式:GET
上限5条,且内容由用户自定义
带有转义
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | array | 信息本体 |
data
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 套了个娃 | 只有1项??? |
data
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
mid | num | 目标用户mid | |
tags | array | TAG名称 |
data
数组中的对象中的tags
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | str | TAG1 | |
n | str | TAG(n+1) | |
…… | str | …… | |
4 | str | TAG5 | 上限5条 |
示例:
查看用户mid=53456
的个人TAG
curl -G 'https://api.bilibili.com/x/space/acc/tags' \
--data-urlencode 'mid=53456'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": [
{
"mid": 53456,
"tags": [
"游戏",
"音乐",
"warma",
"搞笑",
"动画"
]
}
]
}
修改个人TAG
请求方式:POST
认证方式:Cookie(SESSDATA)
鉴权方式:Cookie中DedeUserID
存在且不为0
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
tags | strs | 要设置的TAG内容 | 非必要 | 删除公告留空或省去即可 各TAG长度小于10字符 最多5个TAG 各TAG之间用","(%2C)分隔 重复TAG无效 |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误(超出长度限制) |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
修改个人TAG为minecraft,技术宅,大佬,小哥哥,可爱
curl 'https://api.bilibili.com/x/space/acc/tags/set' \
--data-urlencode 'tags=minecraft,技术宅,大佬,小哥哥,可爱' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx;DedeUserID=1'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
空间公告
查看用户空间公告
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | str | 公告信息 | 无则为空 |
示例:
查看用户mid=53456
的空间公告
curl -G 'https://api.bilibili.com/x/space/notice' \
--data-urlencode 'mid=53456'
查看响应示例:
{
"code":0,
"message":"0",
"ttl":1,
"data":"我的微博 @_warma_\n直播录像上传到:warma养鸽场\n头像画师是:微博@Dr-H_喵_\n横幅画师:@薬屋"
}
修改空间公告
请求方式:POST
认证方式:Cookie(SESSDATA)
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
notice | str | 要设置的公告内容 | 非必要 | 删除公告留空或省去即可 少于150字符 |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -304:未修改 -400:请求错误(超出长度限制) |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | 作用尚不明确 |
示例:
修改个人空间公告为鸽子
curl 'https://api.bilibili.com/x/space/notice/set' \
--data-urlencode 'notice=鸽子' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
主页板块布局与权限
查询空间设置
请求方式:GET
注:带有转义
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
status | bool | 用户是否存在 | true:存在 false:不存在 |
data | 用户存在时:obj 用户不存在时:str |
用户存在时:信息本体 用户不存在时:错误信息 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
privacy | obj | 空间隐私权限 | |
index_order | array | 空间板块布局 | |
theme | str | default主题? | 作用尚不明确 |
theme_preview_img_path | str | 主题预览图路径? | 作用尚不明确 |
toutu | obj | 空间头图 |
privacy
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
bangumi | num | 追番及追剧 | 0:隐藏 1:公开 下同 |
bbq | num | 轻视频 | |
channel | num | 频道 | |
coins_video | num | 最近投币的视频 | |
comic | num | 追漫 | |
dress_up | num | 装扮 | |
fav_video | num | 收藏夹 | |
groups | num | 圈子? | 作用尚不明确 |
likes_video | num | 最近点赞的视频 | |
played_game | num | 最近玩过的游戏 | |
tags | num | 订阅标签 | |
user_info | num | 个人资料 |
index_order
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 板块1 | 根据板块布局顺序排序 先左侧布局后右侧布局 |
n | obj | 板块(n+1) | |
…… | obj | …… | …… |
index_order
数组内对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
id | num | 板块编号 | |
name | str | 板块名称 |
toutu
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
sid | num | 空间头图ID | |
expire | num | 到期时间? | 时间戳? 作用尚不明确 |
s_img | str | 空间头图小图相对路径 | 完整url为http://i0.hdslb.com/ +相对路径 |
l_img | str | 空间头图相对路径 | 同上 |
android_img | str | 空 | 注:手机端头图与web端不同,需要用另一个api获取 |
iphone_img | str | 空 | |
ipad_img | str | 空 | |
thumbnail_img | str | 缩略图 | |
platform | num | 0 | 作用尚不明确 |
示例:
查看mid=2
的空间设置
curl -G 'http://space.bilibili.com/ajax/settings/getSettings' \
--data-urlencode 'mid=2'
查看响应示例:
{
"status":true,
"data":{
"privacy":{
"bangumi":1,
"bbq":1,
"channel":1,
"coins_video":0,
"comic":1,
"dress_up":1,
"fav_video":0,
"groups":0,
"likes_video":0,
"played_game":1,
"tags":1,
"user_info":1
},
"index_order":[
{
"id":1,
"name":"我的稿件"
},
{
"id":8,
"name":"我的专栏"
},
{
"id":7,
"name":"我的频道"
},
{
"id":2,
"name":"我的收藏夹"
},
{
"id":3,
"name":"订阅番剧"
},
{
"id":4,
"name":"订阅标签"
},
{
"id":5,
"name":"最近投币的视频"
},
{
"id":6,
"name":"我的圈子"
},
{
"id":9,
"name":"我的相簿"
},
{
"id":21,
"name":"公告"
},
{
"id":22,
"name":"直播间"
},
{
"id":23,
"name":"个人资料"
},
{
"id":24,
"name":"官方活动"
},
{
"id":25,
"name":"最近玩过的游戏"
}
],
"theme":"default",
"theme_preview_img_path":"",
"toutu":{
"sid":1,
"expire":2861874560,
"s_img":"bfs/space/768cc4fd97618cf589d23c2711a1d1a729f42235.png",
"l_img":"bfs/space/cb1c3ef50e22b6096fde67febe863494caefebad.png",
"android_img":"",
"iphone_img":"",
"ipad_img":"",
"thumbnail_img":"",
"platform":0
}
}
}
调整空间板块布局
请求方式:POST
认证方式:Cookie(SESSDATA)
鉴权方式:Cookie中DedeUserID
及DedeUserID__ckMd5
存在且不为0,referer为 .bilibili.com
域名下
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
index_order | nums | 布局列表 | 必要 | 每个值之间用","(%2C)分隔 先左侧布局再右侧布局 值的意义见下表 |
csrf | str | CSRF Token(位于cookie) | 必要 |
布局参数index_order
:
值 | 含义 |
---|---|
1 | (左侧)我的稿件 |
2 | (左侧)我的收藏夹 |
3 | (左侧)订阅番剧 |
4 | (左侧)订阅标签 |
5 | (左侧)最近投币的视频 |
6 | (左侧)我的圈子**(此板块被隐藏)** |
7 | (左侧)我的频道 |
8 | (左侧)我的专栏 |
9 | (左侧)我的相簿 |
21 | (右侧)公告 |
22 | (右侧)直播间 |
23 | (右侧)个人资料 |
24 | (右侧)官方活动 |
25 | (右侧)最近玩的游戏 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
ststus | bool | 操作结果 | true:操作成功 false:操作失败 |
data | str | 错误信息 | 正确时无此项 |
示例:
调整空间布局为:
我的稿件 直播间 我的专栏 个人资料 订阅番剧 公告 我的收藏夹 官方活动 我的相簿 最近玩的游戏 最近投币的视频 订阅标签 我的频道
curl 'http://space.bilibili.com/ajax/settings/setIndexOrder' \
--data-urlencode 'index_order=1,8,3,2,9,5,4,7,22,23,21,24,25,6' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx;DedeUserID=1;DedeUserID__ckMd5=1;' \
-e 'https://www.bilibili.com'
查看响应示例:
{
"status": true
}
修改空间隐私权限
请求方式:POST
认证方式:Cookie(SESSDATA)
鉴权方式:Cookie中DedeUserID
及DedeUserID__ckMd5
存在且不为0,referer为 .bilibili.com
域名下
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
fav_video | num | 收藏视频 | 非必要 | 0:隐藏 1:公开 下同 |
bangumi | num | 追番及追剧 | 非必要 | |
tags | num | 关注的TAG | 非必要 | |
coins_video | num | 投币的视频 | 非必要 | |
user_info | num | 个人信息 | 非必要 | |
played_game | num | 玩过的游戏 | 非必要 | |
csrf | nstr | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
ststus | bool | 操作结果 | true:操作成功 false:操作失败 |
data | str | 错误信息 | 正确时无此项 |
示例:
设置关注的TAG
为隐藏
curl 'http://space.bilibili.com/ajax/settings/setPrivacy' \
--data-urlencode 'tags=0' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx;DedeUserID=1;DedeUserID__ckMd5=1;' \
-e 'https://www.bilibili.com'
查看响应示例:
{
"status": true
}
查询用户最近玩过的游戏
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 53013:用户隐私设置未公开 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | 隐藏时:null 公开时:array |
信息本体 |
data
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 游戏1 | |
n | obj | 游戏(n+1) | 项数为总计游戏数 |
…… | obj | …… | …… |
data
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
website | str | 游戏主页链接url | |
image | str | 游戏图片url | |
name | str | 游戏名 |
示例:
查询mid=2
的最近玩过的游戏
curl -G 'https://api.bilibili.com/x/space/lastplaygame' \
--data-urlencode 'mid=2'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": [
{
"website": "https://game.bilibili.com/fgo/event_meihosou",
"image": "http://i0.hdslb.com/bfs/game/f7d4ee0877089e4079b8f0b4f5c95dd4ceba512a.png",
"name": "命运-冠位指定(Fate/GO)"
},
{
"website": "https://game.bilibili.com/pcr/xxtix",
"image": "http://i0.hdslb.com/bfs/game/7922ecea5cc76fe3c8c177e1d4a6c8cf1c36a700.jpg",
"name": "公主连结Re:Dive"
},
{
"website": "https://game.bilibili.com/dwbgx/",
"image": "http://i0.hdslb.com/bfs/game/6d5b2df70dfa987408d8d09110cdc327949885e3.png",
"name": "大王不高兴"
},
{
"website": "https://game.bilibili.com/bangdream/1stanniversary-yxzx/",
"image": "http://i0.hdslb.com/bfs/game/4a7d0b7272dffe5a489ee935b6bd2d4f7d5f1257.png",
"name": "BanG Dream!"
},
{
"website": "http://www.biligame.com/detail/?id=101772",
"image": "http://i0.hdslb.com/bfs/game/8e8b04e7bd2170c2ba2c9f563a62c72bac2eba2c.jpg",
"name": "明日方舟"
}
]
}
获取用户最近投币的视频明细
请求方式:GET
认证方式:Cookie(SESSDATA)
如设置隐私查看自己的需要认证
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
vmid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 53013:用户隐私设置未公开 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | 隐藏时:null 公开时:array |
信息本体 |
data
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 投币视频1 | |
n | obj | 投币视频(n+1) | |
…… | obj | …… |
data
数组中的对象:
基本同获取视频详细信息(web端)中的data对象
示例:
查看用户mid=15858903
的最近投币视频
curl -G 'http://space.bilibili.com/x/space/coin/video' \
--data-urlencode 'vmid=15858903' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": [
{
"aid": 669644066,
"videos": 1,
"tid": 75,
"tname": "动物圈",
"copyright": 2,
"pic": "http://i1.hdslb.com/bfs/archive/0f73a68b8f449cc72e9ef109685bd295dc0c0c9d.jpg",
"title": "在人类幼崽身上用尽了温柔",
"pubdate": 1600608261,
"ctime": 1600608261,
"desc": "https://weibo.com/tv/show/1034:4551253766897703?from=old_pc_videoshow",
"state": 0,
"attribute": 16384,
"duration": 29,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 0,
"no_reprint": 0,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 258457966,
"name": "卧龙寺",
"face": "http://i2.hdslb.com/bfs/face/f868d1f522733fdcf72a6267e0237157dd0e9948.jpg"
},
"stat": {
"aid": 669644066,
"view": 3412898,
"danmaku": 719,
"reply": 1481,
"favorite": 21909,
"coin": 2864,
"share": 13702,
"now_rank": 0,
"his_rank": 0,
"like": 86970,
"dislike": 0
},
"dynamic": "",
"cid": 237319289,
"dimension": {
"width": 576,
"height": 1024,
"rotate": 0
},
"bvid": "BV1sa4y1j7jk",
"coins": 1,
"time": 1601802763,
"ip": "",
"inter_video": false
},
{
"aid": 202267998,
"videos": 1,
"tid": 138,
"tname": "搞笑",
"copyright": 1,
"pic": "http://i0.hdslb.com/bfs/archive/ca7746f2207114513f1a421d7f744523275ee679.jpg",
"title": "充 电 器 の 痛",
"pubdate": 1601750952,
"ctime": 1601750952,
"desc": "这个简介吓到我了!",
"state": 0,
"attribute": 16512,
"duration": 50,
"mission_id": 14725,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 0,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 129922746,
"name": "-白糖洒一地-",
"face": "http://i0.hdslb.com/bfs/face/1f581f3b20a380c2fd13ecb8bbe409f8b49c6418.jpg"
},
"stat": {
"aid": 202267998,
"view": 109,
"danmaku": 2,
"reply": 11,
"favorite": 5,
"coin": 9,
"share": 0,
"now_rank": 0,
"his_rank": 0,
"like": 20,
"dislike": 0
},
"dynamic": "",
"cid": 241861687,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV1oh411X7iA",
"coins": 2,
"time": 1601773750,
"ip": "",
"inter_video": false
},
{
"aid": 839722373,
"videos": 1,
"tid": 208,
"tname": "校园学习",
"copyright": 1,
"pic": "http://i2.hdslb.com/bfs/archive/11ed53241ceab314c919adba9f85582d24d9313c.jpg",
"title": "“白piáo”用日语到底怎么说?油管人气日语老师来教你!",
"pubdate": 1601026026,
"ctime": 1601026026,
"desc": "志方老师的B站用语日语课又来了~\n欢迎大家来看哦,\n如果喜欢我们的作品的话,欢迎大家用2~3连+转发来支持我们~\n如果拒绝的话,也可以用日语在评论和弹幕里刷上一波~即可以锻炼日语又可以拒绝我们,岂不美哉~~",
"state": 0,
"attribute": 16768,
"duration": 310,
"mission_id": 14655,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 1,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 677926489,
"name": "日语志方老师",
"face": "http://i2.hdslb.com/bfs/face/d465e5cd42e3523a52b3bef38dce7b23627b7723.jpg"
},
"stat": {
"aid": 839722373,
"view": 130688,
"danmaku": 1320,
"reply": 799,
"favorite": 3722,
"coin": 5883,
"share": 339,
"now_rank": 0,
"his_rank": 0,
"like": 17585,
"dislike": 0
},
"dynamic": "志方老师的B站用语日语课又来了~\n欢迎大家来看哦,\n如果喜欢我们的作品的话,欢迎大家用2~3连+转发来支持我们~\n如果拒绝的话,也可以用日语在评论和弹幕里刷上一波~即可以锻炼日语又可以拒绝我们,岂不美哉~~",
"cid": 238876133,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV1n54y117kq",
"coins": 2,
"time": 1601036198,
"ip": "",
"inter_video": false
}
]
}
投稿
查询用户投稿视频明细
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 | |
order | str | 排序方式 | 非必要 | 默认为pubdate 最新发布:pubdate 最多播放:click 最多收藏:stow |
tid | num | 筛选目标分区 | 非必要 | 默认为0 0:不进行分区筛选 分区tid为所筛选的分区 |
keyword | str | 关键词筛选 | 非必要 | 用于使用关键词搜索该UP主视频稿件 |
pn | num | 页码 | 必要 | |
ps | num | 每页项数 | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 -412:请求被拦截 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | obj | 信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
list | obj | 列表信息 | |
page | obj | 页面信息 | |
episodic_button | obj | “播放全部“按钮 |
data
中的list
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
tlist | obj | 投稿视频分区索引 | |
vlist | array | 投稿视频列表 |
list
中的tlist
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
{tid} | obj | 该分区的详情 | 字段名为存在的分区tid |
…… | obj | …… | 向下扩展 |
tlist
中的{tid}
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 投稿至该分区的视频数 | |
name | str | 该分区名称 | |
tid | num | 该分区tid |
list
中的vlist
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 投稿视频1 | |
n | obj | 投稿视频(n+1) | |
…… | obj | …… | …… |
list
中的vlist
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
aid | num | 稿件avid | |
author | str | 视频UP主 | 不一定为目标用户(合作视频) |
bvid | str | 稿件bvid | |
comment | num | 视频评论数 | |
copyright | str | 空 | 作用尚不明确 |
created | num | 投稿时间 | 时间戳 |
description | str | 视频简介 | |
hide_click | bool | false | 作用尚不明确 |
is_pay | num | 0 | 作用尚不明确 |
is_union_video | num | 是否为合作视频 | 0:否 1:是 |
length | str | 视频长度 | MM:SS |
mid | num | 视频UP主mid | 不一定为目标用户(合作视频) |
pic | str | 视频封面 | |
play | num | 视频播放次数 | |
review | num | 0 | 作用尚不明确 |
subtitle | str | 空 | 作用尚不明确 |
title | str | 视频标题 | |
typeid | num | 视频分区tid | |
video_review | num | 视频弹幕数 |
data
中的page
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 总计稿件数 | |
pn | num | 当前页码 | |
ps | num | 每页项数 |
data
中的episodic_button
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
text | str | 按钮文字 | |
uri | str | 全部播放页url |
示例:
pn
(页码)和ps
(每页项数)只改变vlist
中成员的多少与内容
以每页2项查询用户mid=53456
的第1页投稿视频明细
curl -G 'https://api.bilibili.com/x/space/arc/search' \
--data-urlencode 'mid=53456' \
--data-urlencode 'ps=2' \
--data-urlencode 'pn=1'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"list": {
"tlist": {
"1": {
"tid": 1,
"count": 26,
"name": "动画"
},
"160": {
"tid": 160,
"count": 42,
"name": "生活"
},
"211": {
"tid": 211,
"count": 3,
"name": "美食"
},
"3": {
"tid": 3,
"count": 33,
"name": "音乐"
},
"4": {
"tid": 4,
"count": 72,
"name": "游戏"
}
},
"vlist": [
{
"comment": 3558,
"typeid": 47,
"play": 1275661,
"pic": "//i2.hdslb.com/bfs/archive/90157806a34646ac2d4c6af3e8b6156cb3460d14.jpg",
"subtitle": "",
"description": "第一期:BV1ak4y1B7aG\n第二期:BV1eA411Y7FN\n脚本/绘画/配音/动画/片尾曲:warma\n第三期终于做完啦!这是一个以我平时发呆的时候想到的一些灵感组成的冷笑话合集,名字叫《沃玛的生活》,可以当作日常搞笑单元小动画来看。\n如果你喜欢这个系列的话请点赞投币收藏一键三连给我一些继续制作的动力吧,我真的非常非常需要更多的动力!\n祝看得开心~\n我的微博:@_warma_",
"copyright": "",
"title": "【warma】沃玛的新番更新!从现在开始放飞自我【沃玛的生活/第三期】",
"review": 0,
"author": "Warma",
"mid": 53456,
"created": 1605844817,
"length": "05:16",
"video_review": 7470,
"aid": 585275804,
"bvid": "BV1sz4y1y7KJ",
"hide_click": false,
"is_pay": 0,
"is_union_video": 0,
"is_steins_gate": 0
},
{
"comment": 2979,
"typeid": 21,
"play": 840676,
"pic": "//i2.hdslb.com/bfs/archive/b43f88c6ebae8fdc7dfb663f6f6f2931b924c763.jpg",
"subtitle": "",
"description": "前一阵子过生日,大家的礼物经过几番转寄终于收到了~于是录了这期礼物开箱视频。\n现在也在感慨,大家的礼物真的都太强了,居然这些全都是手工做的,真的好厉害!\n这些手工礼物背后得花多少时间和心力啊……这些对我来说都是无价的礼物,制作礼物的大家真的有心了,谢谢!!\n收到这些礼物真的很开心,视频的封面也是在这样激动的情况下画出来的,祝你看得开心~\n我的微博:@_warma_",
"copyright": "",
"title": "【warma】来开箱!大家寄来的生日礼物",
"review": 0,
"author": "Warma",
"mid": 53456,
"created": 1604635221,
"length": "24:28",
"video_review": 10476,
"aid": 287744380,
"bvid": "BV1xf4y1q7XN",
"hide_click": false,
"is_pay": 0,
"is_union_video": 0,
"is_steins_gate": 0
}
]
},
"page": {
"pn": 1,
"ps": 2,
"count": 176
},
"episodic_button": {
"text": "播放全部",
"uri": "//www.bilibili.com/medialist/play/53456?from=space"
}
}
}
查询用户投稿相簿预览
请求方式:GET
所有类型的相簿
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 | |
ps | num | 获取的相簿量 | 非必要 | 默认为8 定义域 1-大于1700 (注意滥用风险) |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | array | 相簿列表 |
data
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 相簿内容1 | |
n | obj | 相簿内容(n+1) | |
…… | obj | …… | …… |
data
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 总计图片数 | |
ctime | num | 发布时间 | 时间戳 |
description | str | 简介 | |
doc_id | num | 相簿id | 非动态!!! |
like | num | 点赞数 | |
pictures | array | 图片内容 | |
poster_uid | num | 上传用户mid | |
title | str | 标题 | 动态内容无 |
view | num | 浏览数 |
data
数组中的对象中的pictures
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 内容图片1 | |
n | obj | 内容图片(n+1) | 项数取决于count 的值 |
…… | obj | …… | …… |
pictures
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
img_height | num | 图片高度 | |
img_size | num | 图片大小 | 单位为KByte |
img_src | str | 图片url | |
img_width | num | 图片宽度 |
示例:
查询用户mid=53456
的投稿相簿预览
curl -G 'https://api.bilibili.com/x/space/album/index' \
--data-urlencode 'mid=53456' \
--data-urlencode 'ps=2'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": [{
"doc_id": 60470424,
"poster_uid": 53456,
"title": "",
"description": "你醒啦![tv_大佬]\n之前说到过的百万粉纪念的视频已经定时在了今天下午七点,欢迎来看呀!",
"pictures": [{
"img_src": "https://i0.hdslb.com/bfs/album/2840366e30bf7c0aba9da5adde1a771255a57bc7.jpg",
"img_width": 625,
"img_height": 134,
"img_size": 14
}],
"count": 1,
"ctime": 1583444859,
"view": 1677521,
"like": 29974
}, {
"doc_id": 58962388,
"poster_uid": 53456,
"title": "",
"description": "上次的那些写实儿童画发出来啦!可以打印下来辟邪[tv_大佬]",
"pictures": [{
"img_src": "https://i0.hdslb.com/bfs/album/8acaf7c7897cb858cccab36c33a5e875adfef177.jpg",
"img_width": 2172,
"img_height": 3258,
"img_size": 2831
}, {
"img_src": "https://i0.hdslb.com/bfs/album/1611b6b56d3d4328889a62b9f9bdc92e9d065532.jpg",
"img_width": 3456,
"img_height": 5184,
"img_size": 3024
}, {
"img_src": "https://i0.hdslb.com/bfs/album/f3a30a2ef5b39711af8b945d54d85ffd1e932b8a.jpg",
"img_width": 1200,
"img_height": 757,
"img_size": 313
}],
"count": 3,
"ctime": 1582881332,
"view": 1176646,
"like": 25734
}]
}
查询用户投稿相簿明细
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
uid | num | 目标用户mid | 必要 | |
page_num | num | 页码 | 非必要 | 默认为1 |
page_size | num | 每页项数 | 非必要 | 默认为20 |
biz | str | 查询类型 | 非必要 | 全部:all 绘画:draw 摄影:photo 日常:daily 默认为all |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 |
msg | str | 错误信息 | 默认为success |
message | str | 错误信息 | 默认为success |
data | obj | 信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
items | array | 相簿列表 |
items
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 相簿内容1 | |
n | obj | 相簿内容(n+1) | |
…… | obj | …… | …… |
items
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 总计图片数 | |
ctime | num | 发布时间 | 时间戳 |
description | str | 简介 | |
doc_id | num | 相簿id | 非动态!!! |
like | num | 点赞数 | |
pictures | array | 图片内容 | |
poster_uid | num | 上传用户mid | |
title | str | 标题 | 动态内容无 |
view | num | 浏览数 |
items
数组中的对象中的pictures
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 内容图片1 | |
n | obj | 内容图片(n+1) | 项数取决于count 的值 |
…… | obj | …… | …… |
pictures
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
img_height | num | 图片高度 | |
img_size | num | 图片大小 | 单位为KByte |
img_src | str | 图片url | |
img_width | num | 图片宽度 |
示例:
查询用户mid=53456
的投稿明细中的全部类型
curl -G 'https://api.vc.bilibili.com/link_draw/v1/doc/doc_list' \
--data-urlencode 'uid=2' \
--data-urlencode 'page_num=1' \
--data-urlencode 'page_size=2' \
--data-urlencode 'biz=all'
查看响应示例:
{
"code": 0,
"msg": "success",
"message": "success",
"data": {
"items": [{
"doc_id": 59015720,
"poster_uid": 2,
"title": "",
"description": "6影是真的无脑,2个宝石都护不住(设计师:这真是太酷了)",
"pictures": [{
"img_src": "http://i0.hdslb.com/bfs/album/8456f050ec8639c6e0cef36aba27bfdedc550590.jpg",
"img_width": 1824,
"img_height": 840,
"img_size": 1024
}],
"count": 1,
"ctime": 1582894607,
"view": 707073,
"like": 7055
}, {
"doc_id": 46853140,
"poster_uid": 2,
"title": "",
"description": "#年度报告# #新年Flag# https://www.bilibili.com/blackboard/timemachine2019.html\n决定了,这就是我的新年Flag!今年我一定要…",
"pictures": [{
"img_src": "http://i0.hdslb.com/bfs/album/5b3ae76f79d7cf2501afc3ca7c7da509dcf0e38a.jpg",
"img_width": 1125,
"img_height": 2184,
"img_size": 465
}, {
"img_src": "http://i0.hdslb.com/bfs/album/87789fe9644337a1f7e6a0655a32584705af8bda.jpg",
"img_width": 1125,
"img_height": 2184,
"img_size": 421
}, {
"img_src": "http://i0.hdslb.com/bfs/album/f752d7f3bb7952f6c0013b3f48ddcb07060b4721.jpg",
"img_width": 1125,
"img_height": 2184,
"img_size": 524
}, {
"img_src": "http://i0.hdslb.com/bfs/active/7a52a411bccb716c8e67fe70e6c330d5209346de.jpg",
"img_width": 1125,
"img_height": 2184,
"img_size": 534
}],
"count": 4,
"ctime": 1577966163,
"view": 833193,
"like": 5667
}]
}
}
频道
查询用户频道列表
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | obj | 信息本体 | 无则为空 所有频道内均无视频则为空,此时code为0 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 总计频道数 | |
list | array | 频道列表 |
data
中的list
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 频道1 | |
n | obj | 频道(n+1) | 项数取决于count 的值 |
…… | obj | …… | …… |
data
中的list
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
cid | num | 频道id | |
count | num | 频道内含视频数 | |
cover | str | 封面图片url | |
intro | str | 简介 | 无则为空 |
mid | num | 创建用户mid | |
mtime | num | 创建时间 | 时间戳 |
name | str | 标题 |
示例:
查询用户mid=53456
的频道列表
curl -G 'https://api.bilibili.com/x/space/channel/list' \
--data-urlencode 'mid=53456'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"count": 6,
"list": [{
"cid": 100249,
"mid": 53456,
"name": "【实况】动物之森",
"intro": "",
"mtime": 1579898830,
"count": 2,
"cover": "http://i1.hdslb.com/bfs/archive/6a7ed9483c34e839dfca981b9e2b94cd4c4efa0a.jpg"
}, {
"cid": 79323,
"mid": 53456,
"name": "忆雨",
"intro": "忆雨出现过的视频",
"mtime": 1562535222,
"count": 7,
"cover": "http://i2.hdslb.com/bfs/archive/1783e4f03042b282495799adda1cb56270cea647.jpg"
}, {
"cid": 79322,
"mid": 53456,
"name": "大画家",
"intro": "",
"mtime": 1562535122,
"count": 6,
"cover": "http://i0.hdslb.com/bfs/archive/9c85a14e805c6c23cb7a42e1dbef97821bb68960.jpg"
}, {
"cid": 77758,
"mid": 53456,
"name": "灭火器",
"intro": "",
"mtime": 1561270856,
"count": 4,
"cover": "http://i2.hdslb.com/bfs/archive/0073208d086b4ebe9cdc540e7664aa74b483aeb6.jpg"
}, {
"cid": 75696,
"mid": 53456,
"name": "沃玛小剧场",
"intro": "",
"mtime": 1559129460,
"count": 5,
"cover": "http://i2.hdslb.com/bfs/archive/db2b20ecdb6ed013fc3780b0e741ea88d46b5b40.jpg"
}, {
"cid": 170,
"mid": 53456,
"name": "爆炸电台",
"intro": "闲聊的电台",
"mtime": 1503298893,
"count": 7,
"cover": "http://i2.hdslb.com/bfs/archive/73d77bc6bb0d44b239fd4f5a2682fe3144e81692.jpg"
}]
}
}
查询用户频道中的视频
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 | |
cid | num | 目标频道id | 必要 | |
pn | num | 页码 | 非必要 | 默认为1 |
ps | num | 每页项数 | 非必要 | 默认为100 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 -404:无用户对应的频道 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | obj | 信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
list | obj | 频道信息 | |
page | obj | 页面信息 |
data
中的list
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
archives | array | 包含的视频列表 | |
cid | num | 频道id | |
count | num | 频道内含视频数 | |
cover | str | 封面图片url | |
intro | str | 简介 | 无则为空 |
mid | num | 创建用户mid | |
mtime | num | 创建时间 | 时间戳 |
name | str | 标题 |
list
中的archives
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 视频1 | |
n | obj | 视频(n+1) | 项数取决于count 的值 |
…… | obj | …… | …… |
list
中的archives
数组中的对象:
基本同「视频详细信息」中的data对象
data
中的page
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 总计视频数 | |
num | num | 当前页码 | |
size | num | 每页项数 |
示例:
查询用户mid=53456
的频道170
中的视频
curl -G 'https://api.bilibili.com/x/space/channel/video' \
--data-urlencode 'mid=53456' \
--data-urlencode 'cid=170' \
--data-urlencode 'ps=2' \
--data-urlencode 'pn=1'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"list": {
"cid": 170,
"mid": 53456,
"name": "爆炸电台",
"intro": "闲聊的电台",
"mtime": 1503298893,
"count": 7,
"cover": "http://i2.hdslb.com/bfs/archive/73d77bc6bb0d44b239fd4f5a2682fe3144e81692.jpg",
"archives": [{
"aid": 87673204,
"videos": 1,
"tid": 21,
"tname": "日常",
"copyright": 1,
"pic": "http://i0.hdslb.com/bfs/archive/5387bdcbbe4d5551adbf0ee2e607e4b7d3d8f2f0.jpg",
"title": "【warma爆炸电台】迟来的自我介绍【第八期】",
"pubdate": 1581244539,
"ctime": 1581244540,
"desc": "时隔半年的新的一期爆炸电台来啦,这是我的一系列杂谈聊天电台,这次因为多了很多新关注的朋友们,所以来做个自我介绍吧!\n画师:Dr-H_喵_ 动画:K_Lacid\n结尾提到的壁纸稍后在动态发原图,动态壁纸在steam那个壁纸软件的创意工坊里搜warma能找到\n\n往期的电台:\n第一期:av6786024 \n第三期:av13619263\n第四期:av18862091\n第五期:av25092410\n第六期:av42492515\n第七期:av62910468",
"state": 0,
"attribute": 16512,
"duration": 2388,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 0,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 53456,
"name": "Warma",
"face": "http://i1.hdslb.com/bfs/face/c1bbee6d255f1e7fc434e9930f0f288c8b24293a.jpg"
},
"stat": {
"aid": 87673204,
"view": 1383542,
"danmaku": 88908,
"reply": 9237,
"favorite": 32929,
"coin": 68849,
"share": 5140,
"now_rank": 0,
"his_rank": 52,
"like": 116164,
"dislike": 0
},
"dynamic": "来做个自我介绍吧! #warma##沃玛##爆炸电台#",
"cid": 149793525,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV1D7411t7Be",
"inter_video": false
}, {
"aid": 62910468,
"videos": 1,
"tid": 21,
"tname": "日常",
"copyright": 1,
"pic": "http://i2.hdslb.com/bfs/archive/4bd598f71a144d4505e259b143c0de0bf27968b2.jpg",
"title": "【warma爆炸电台】居然收到了几千条问题!【第七期】",
"pubdate": 1565345410,
"ctime": 1565338559,
"desc": "时隔半年的爆炸电台第七期终于来啦!在这一期里回答了很多问题,祝看得开心!此外,就在昨天,50万订阅了…真的谢谢大家!\n也欢迎来看往期的电台:\n第一期:av6786024 (2016年10月)\n第二期:av10373352(2017年5月)\n第三期:av13619263(2017年8月)\n第四期:av18862091(2018年1月)\n第五期:av25092410(2018年6月)\n第六期:av42492515(2019年2月)",
"state": 0,
"attribute": 16512,
"duration": 1987,
"mission_id": 11740,
"rights": {
"bp": 0,
"elec": 0,
"download": 0,
"movie": 0,
"pay": 0,
"hd5": 0,
"no_reprint": 1,
"autoplay": 1,
"ugc_pay": 0,
"is_cooperation": 0,
"ugc_pay_preview": 0,
"no_background": 0
},
"owner": {
"mid": 53456,
"name": "Warma",
"face": "http://i1.hdslb.com/bfs/face/c1bbee6d255f1e7fc434e9930f0f288c8b24293a.jpg"
},
"stat": {
"aid": 62910468,
"view": 455277,
"danmaku": 19383,
"reply": 2108,
"favorite": 10507,
"coin": 19422,
"share": 1208,
"now_rank": 0,
"his_rank": 0,
"like": 31515,
"dislike": 0
},
"dynamic": "爆炸电台 第七期 来啦!",
"cid": 109284065,
"dimension": {
"width": 1920,
"height": 1080,
"rotate": 0
},
"bvid": "BV1gt411K7Ga",
"inter_video": false
}]
},
"page": {
"count": 7,
"num": 1,
"size": 2
}
}
}
创建频道
请求方式:POST
认证方式:Cookie(SESSDATA)
创建成功后会返回新建频道的id
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
name | str | 频道名 | 必要 | |
intro | str | 频道简介 | 非必要 | |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 53001:频道名字数超过限制 53002:频道简介字数超过限制 53004:创建的频道已经满额 53007:频道名称已经存在 53024:编辑内容命中敏感信息 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | obj | 数据本体 | 成功有此项 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
cid | num | 频道id |
示例:
创建名为test1
的频道,简介为空
curl 'https://api.bilibili.com/x/space/channel/add' \
--data-urlencode 'name=test1' \
--data-urlencode 'intro=' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"cid": 138996
}
}
修改频道
请求方式:POST
认证方式:Cookie(SESSDATA)
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
cid | num | 频道id | 必要 | |
name | str | 频道名 | 必要 | |
intro | str | 频道简介 | 非必要 | |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 53001:频道名字数超过限制 53002:频道简介字数超过限制 53007:频道名称已经存在 53024:编辑内容命中敏感信息 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
修改频道138996
名称为测试
,简介为123456
curl 'https://api.bilibili.com/x/space/channel/edit' \
--data-urlencode 'cid=138996' \
--data-urlencode 'name=测试' \
--data-urlencode 'intro=123456' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
删除频道
请求方式:POST
认证方式:Cookie(SESSDATA)
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
cid | num | 需要删除的频道id | 必要 | |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
删除频道138996
curl 'https://api.bilibili.com/x/space/channel/del' \
--data-urlencode 'cid=138996' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
频道添加视频
请求方式:POST
认证方式:Cookie(SESSDATA)
仅能添加自己是UP主的视频
如添加多个视频,仅会添加正确的
注:完成后需要使用接口「查询用户频道中的视频」刷新
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
cid | num | 频道id | 必要 | |
aids | nums | 要添加的目标稿件avid | 必要 | 多个使用","(%2C)分隔 |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 -404:无此项 53003:本频道里的视频已满 53006:提交视频已失效或频道里有(非该视频UP主) |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | array | 出错稿件avid列表 |
data
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | num | 出错稿件avid1 | |
n | num | 出错稿件avid(n+1) | |
…… | num | …… | …… |
示例:
向频道138995
中添加视频av583785685
和av243322853
curl 'https://api.bilibili.com/x/space/channel/video/add' \
--data-urlencode 'cid=138995' \
--data-urlencode 'aids=583785685,243322853' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": []
}
频道删除视频
请求方式:POST
认证方式:Cookie(SESSDATA)
注:完成后需要使用接口「查询用户频道中的视频」刷新
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
cid | num | 频道id | 必要 | |
aid | num | 要删除的目标稿件avid | 必要 | |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 -404:无此项 53008:频道内没有视频 53009:频道内没有该视频 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
删除频道138995
中的视频av583785685
curl 'https://api.bilibili.com/x/space/channel/video/del' \
--data-urlencode 'cid=138995' \
--data-urlencode 'aid=583785685' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
调整频道视频排序
请求方式:POST
认证方式:Cookie(SESSDATA)
正文参数( application/x-www-form-urlencoded ):
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
cid | num | 频道id | 必要 | |
aid | num | 要移动的目标稿件avid | 必要 | |
to | num | 视频排序倒数位置 | 非必要 | 默认为1 1为列表底部,视频总数为首端 与显示顺序恰好相反 |
csrf | str | CSRF Token(位于cookie) | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 -400:请求错误 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
调整138995
中的视频av583785685
位置为倒数第2
curl 'https://api.bilibili.com/x/space/channel/video/sort' \
--data-urlencode 'cid=138995' \
--data-urlencode 'aid=583785685' \
--data-urlencode 'to=2' \
--data-urlencode 'csrf=xxx' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
检查频道中有无失效视频
请求方式:GET
认证方式:Cookie(SESSDATA)
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
cid | num | 目标频道id | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -400:请求错误 -404:无此项 53005:频道内有失效视频 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 |
示例:
检查频道138995
curl -G 'https://api.bilibili.com/x/space/channel/video/check
--data-urlencode 'cid=138995' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1
}
收藏
查询用户创建的视频收藏夹
请求方式:GET
认证方式:Cookie(SESSDATA)
查看私有收藏夹时需要认证
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
up_mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | 隐藏时:null 公开时:obj |
信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 创建的收藏夹数 | |
list | 无收藏夹时:null 有收藏夹时:array |
收藏夹列表 |
data
中的list
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 收藏夹1 | |
n | obj | 收藏夹(n+1) | 项数取决于count 的值 |
…… | obj | …… |
data
中的list
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
id | num | 收藏夹mlid | |
fid | num | 原始收藏夹mlid | 去除两位mid尾号 |
mid | num | 创建用户mid | |
attr | num | 收藏夹属性位配置 | |
title | str | 收藏夹标题 | |
fav_state | num | 0 | 作用尚不明确 |
media_count | num | 收藏夹总计视频数 |
attr
属性位二进制值表:
位 | 内容 | 备注 |
---|---|---|
0 | 是否为默认收藏夹 | 0:默认收藏夹 1:其他收藏夹 |
1 | 私有收藏夹 | 0:公开 1:私有 |
其他有待补充... |
示例:
查询用户mid=7792521
的收藏夹列表
curl -G 'https://api.bilibili.com/x/v3/fav/folder/created/list-all' \
--data-urlencode 'up_mid=7792521' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"count": 5,
"list": [{
"id": 44233921,
"fid": 442339,
"mid": 7792521,
"attr": 0,
"title": "默认收藏夹",
"fav_state": 0,
"media_count": 85
}, {
"id": 936347621,
"fid": 9363476,
"mid": 7792521,
"attr": 22,
"title": "放假君的鬼畜私房歌",
"fav_state": 0,
"media_count": 2
}, {
"id": 845218621,
"fid": 8452186,
"mid": 7792521,
"attr": 22,
"title": "♪一言不合就开唱♪",
"fav_state": 0,
"media_count": 4
}, {
"id": 844998121,
"fid": 8449981,
"mid": 7792521,
"attr": 22,
"title": "个人作品精选",
"fav_state": 0,
"media_count": 25
}, {
"id": 381779121,
"fid": 3817791,
"mid": 7792521,
"attr": 22,
"title": "鬼畜小课堂",
"fav_state": 0,
"media_count": 25
}]
}
}
查询用户收藏的视频收藏夹
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
ps | num | 每页项数 | 必要 | 定义域 1 - 大于70 |
pn | num | 页码 | 必要 | |
up_mid | num | 目标用户mid | 必要 | |
platform | str | 平台类型 | 非必要 | 填写web 返回值才会包含用户收藏的视频合集 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -101:账号未登录 -111:csrf校验失败 40022:签名过长 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | 隐藏时:null 公开时:obj |
信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 创建的收藏夹数 | |
list | 无收藏夹时:null 有收藏夹时:array |
收藏夹列表 |
data
中的list
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 收藏夹1 | |
n | obj | 收藏夹(n+1) | 项数取决于count 的值 |
…… | obj | …… |
data
中的list
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
id | num | 收藏夹ml | |
fid | num | 原始收藏夹mlid | 去除两位mid尾号 |
mid | num | 创建用户mid | |
attr | num | 收藏夹属性 | 转换成8-bit二进制处理 详细说明见下表 |
title | str | 收藏夹标题 | |
cover | str | 收藏夹封面图片url | |
upper | obj | 收藏夹创建用户信息 | |
cover_type | num | 2 | 作用尚不明确 |
intro | str | 空 | 作用尚不明确 |
ctime | num | 创建时间 | 时间戳 |
mtime | num | 审核时间 | 时间戳 |
state | num | 0 | 作用尚不明确 |
fav_state | num | 0 | 作用尚不明确 |
media_count | num | 收藏夹总计视频数 |
attr
属性二进制值表:
其他有待补充... | 1:默认收藏夹 | 0:公开性 |
---|---|---|
0:默认收藏夹 1:其他收藏夹 |
0:公开 1:私有 |
data
中的list
数组中的对象中的upper
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
mid | num | 创建人mid | |
name | str | 创建人昵称 | |
face | str | 空 | 作用尚不明确 |
示例:
查询用户mid=293793435
的收藏夹收藏列表
curl -G 'https://api.bilibili.com/x/v3/fav/folder/collected/list' \
--data-urlencode 'up_mid=293793435' \
--data-urlencode 'ps=20' \
--data-urlencode 'pn=1' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"count": 2,
"list": [{
"id": 496307088,
"fid": 4963070,
"mid": 412466388,
"attr": 22,
"title": "入站必刷",
"cover": "http://i0.hdslb.com/bfs/archive/baae2b4050363c0ab45465b7cf696b8304fdaca8.jpg",
"upper": {
"mid": 412466388,
"name": "热门菌",
"face": ""
},
"cover_type": 2,
"intro": "",
"ctime": 1563394571,
"mtime": 1563394571,
"state": 0,
"fav_state": 0,
"media_count": 55
}, {
"id": 381779121,
"fid": 3817791,
"mid": 7792521,
"attr": 22,
"title": "鬼畜小课堂",
"cover": "http://i2.hdslb.com/bfs/archive/09a668cfdb38fb3a85f905c10f48a2947e36a695.jpg",
"upper": {
"mid": 7792521,
"name": "还有一天就放假了",
"face": ""
},
"cover_type": 2,
"intro": "",
"ctime": 1553700224,
"mtime": 1557291666,
"state": 0,
"fav_state": 0,
"media_count": 25
}]
}
}
课程
查询用户发布的课程列表
请求方式:GET
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 | |
pn | num | 页码 | 非必要 | 默认为1 |
ps | num | 每页项数 | 非必要 | 默认为20 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 53013:用户隐私设置未公开 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | obj | 信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
list | array | 课程列表 | |
page | obj | 页面信息 |
data
中的page
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
next | bool | 是否存在下一页 | false:最后一页 true:存在下一页 |
num | num | 当前页码 | |
size | num | 每页项数 | |
total | num | 总计项数 |
data
中的list
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 课程1 | |
n | obj | 课程(n+1) | 按照目标用户的发布顺序排列 |
…… | obj | …… |
data
中的list
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
cover | str | 课程封面url | |
ep_count | num | 课程集数 | |
link | str | 课程页面url | 手机版页面url |
page | num | 1 | 作用尚不明确 |
play | num | 课程播放数 | |
season_id | num | 课程ssid | |
status | str | 更新状态说明 | |
subtitle | str | 课程副标题 | |
title | str | 课程标题 |
示例:
查询用户mid=33683045
的课程发布列表
curl -G 'https://api.bilibili.com/pugv/app/web/season/page' \
--data-urlencode 'mid=33683045' \
--data-urlencode 'ps=5' \
--data-urlencode 'pn=1'
查看响应示例:
{
"code": 0,
"data": {
"items": [
{
"cover": "http://i0.hdslb.com/bfs/archive/596575057885fff7f0ceff047437186cba459358.jpg",
"ep_count": 10,
"link": "https://m.bilibili.com/cheese/play/ss80",
"page": 1,
"play": 174467,
"season_id": 80,
"status": "共10期",
"subtitle": "百科全书式军事科普短视频系列",
"title": "《战忽知道》第一季"
},
{
"cover": "http://i0.hdslb.com/bfs/archive/322aa94d27cece62d2a859caf71ac2426f29eee2.jpg",
"ep_count": 1,
"link": "https://m.bilibili.com/cheese/play/ss145",
"page": 1,
"play": 22155,
"season_id": 145,
"status": "更新至第1期",
"subtitle": "此课程为《局座:第四次工业革命来了》部分集数,请谨慎购买",
"title": "【体验课】局座讲5G:5G如何改变我们的生活?"
},
{
"cover": "http://i0.hdslb.com/bfs/archive/b9794ac4507f8764e219df413b661b5faf499a19.jpg",
"ep_count": 10,
"link": "https://m.bilibili.com/cheese/play/ss113",
"page": 1,
"play": 49833,
"season_id": 113,
"status": "更新至第10期",
"subtitle": "百科全书式军事科普短视频系列",
"title": "《战忽知道》第二季"
},
{
"cover": "http://i0.hdslb.com/bfs/archive/7351fcb33592a4bc7aac9f71d421b4b5ce0177d3.jpg",
"ep_count": 10,
"link": "https://m.bilibili.com/cheese/play/ss51",
"page": 1,
"play": 4981037,
"season_id": 51,
"status": "共10期",
"subtitle": "洞悉国际局势,学习战略思维",
"title": "局座的国际战略课"
},
{
"cover": "http://i0.hdslb.com/bfs/archive/31e2a170b5a815e34f0537a2727b28f1b87dca18.jpg",
"ep_count": 10,
"link": "https://m.bilibili.com/cheese/play/ss121",
"page": 1,
"play": 30754,
"season_id": 121,
"status": "更新至第10期",
"subtitle": "百科全书式军事科普短视频系列",
"title": "《战忽知道》第三季"
}
],
"page": {
"next": true,
"num": 1,
"size": 5,
"total": 8
}
},
"message": "success"
}
订阅
查询用户追番预览列表
请求方式:GET
认证方式:Cookie(SESSDATA)
如设置隐私查看自己的需要认证
带有转义,且只能获取最多15条
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
status | bool | 状态 | false:失败 true:成功 |
data | 失败:str 成功:obj |
失败:错误信息 成功:信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
count | num | 总计追番数 | |
pages | num | 0 | 作用尚不明确 |
result | array | 追番预览列表 |
data
中的result
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 追番1 | |
n | obj | 追番(n+1) | 按照目标用户的关注顺序排列 |
…… | obj | …… | |
14 | obj | 追番15 | 最后一项 |
data
中的result
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
brief | str | 简介 | |
cover | str | 封面图片url | |
evaluate | str | 空 | |
favorites | num | 追番数 | |
is_finish | num | 是否已完结 | 0:未完结 1:已完结 |
last_ep_index | num | 0 | 作用尚不明确 |
newest_ep_index | num | 最新一话 | 可能为0 |
season_id | str | 番剧ssid | |
share_url | str | 播放页面链接url | |
title | str | 标题 | |
total_count | num | 总计集数 | 未完结:-1 已完结:非0正整数 |
示例:
查看用户mid=14082
的追番预览列表
curl -G 'http://space.bilibili.com/ajax/Bangumi/getList' \
--data-urlencode 'mid=14082' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"status": true,
"data": {
"count": 25,
"pages": 0,
"result": [{
"season_id": "29310",
"share_url": "http:\/\/bangumi.bilibili.com\/anime\/29310\/",
"title": "异度侵入 ID:INVADED",
"is_finish": 1,
"favorites": 3479220,
"newest_ep_index": 13,
"last_ep_index": 0,
"total_count": 13,
"cover": "http:\/\/i0.hdslb.com\/bfs\/bangumi\/image\/9bf9e66968f85b33ec3769a16c86b36dc984abbc.png",
"evaluate": "",
"brief": "本片讲述利用能检测出人们杀意的装置以及利用思想粒子做出的“井”,来探知事件真相的科幻故事。"
}, {
"season_id": "25739",
"share_url": "http:\/\/bangumi.bilibili.com\/anime\/25739\/",
"title": "关于我转生变成史莱姆这档事",
"is_finish": 1,
"favorites": 5518829,
"newest_ep_index": 0,
"last_ep_index": 0,
"total_count": 27,
"cover": "http:\/\/i0.hdslb.com\/bfs\/bangumi\/a4c0e0ccc44fe3949a734f546cf5bb07da925bad.png",
"evaluate": "",
"brief": "史莱姆生活,开始了。\n上班族的三上悟在道路上被歹徒给刺杀身亡后,回过神来发现自己转生到了异世界。\n不..."
},
…………
]
}
}
查询用户追番(追剧)明细
请求方式:GET
认证方式:Cookie(SESSDATA)
如设置隐私查看自己的需要认证
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
vmid | num | 目标用户mid | 必要 | |
pn | num | 页码 | 非必要 | 默认为1 |
ps | num | 每页项数 | 非必要 | 默认为15 定义域1-30 |
type | num | 查询类型 | 必要 | 1:追番 2:追剧 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
code | num | 返回值 | 0:成功 -400:请求错误 53013:用户隐私设置未公开 |
message | str | 错误信息 | 默认为0 |
ttl | num | 1 | |
data | obj | 信息本体 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
list | array | 追番列表 | |
pn | num | 当前页码 | |
ps | num | 每页项数 | |
total | num | 总计追番数 |
data
中的list
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 追番1 | |
n | obj | 追番(n+1) | 按照目标用户的关注顺序排列 |
…… | obj | …… |
data
中的list
数组中的对象:
基本同「番剧详细信息」中的result对象(未完工)
示例:
查看用户mid=14082
的追番明细
curl -G 'https://api.bilibili.com/x/space/bangumi/follow/list' \
--data-urlencode 'vmid=14082' \
--data-urlencode 'type=1' \
--data-urlencode 'ps=2' \
--data-urlencode 'pn=1' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"code": 0,
"message": "0",
"ttl": 1,
"data": {
"list": [{
"season_id": 29310,
"media_id": 28224080,
"season_type": 1,
"season_type_name": "番剧",
"title": "异度侵入 ID:INVADED",
"cover": "http://i0.hdslb.com/bfs/bangumi/image/9bf9e66968f85b33ec3769a16c86b36dc984abbc.png",
"total_count": 13,
"is_finish": 1,
"is_started": 1,
"is_play": 1,
"badge": "会员专享",
"badge_type": 0,
"rights": {
"allow_review": 1,
"is_selection": 1,
"selection_style": 1
},
"stat": {
"follow": 3475768,
"view": 87500861,
"danmaku": 1334654,
"reply": 316632,
"coin": 835150,
"series_follow": 3475242,
"series_view": 87500861
},
"new_ep": {
"id": 307774,
"index_show": "全13话",
"cover": "http://i0.hdslb.com/bfs/archive/3dce2b856a7b0ea667aa288b51b7c0478fa56c4d.jpg",
"title": "13",
"long_title": "CHANNELEDⅡ",
"pub_time": "2020-03-23 00:30:00",
"duration": 1481000
},
"rating": {
"score": 9.8,
"count": 262589
},
"square_cover": "http://i0.hdslb.com/bfs/bangumi/image/664dbf039ec2da8dd982b697a108e28e87b9897e.jpg",
"season_status": 13,
"season_title": "TV",
"badge_ep": "会员",
"media_attr": 196608,
"season_attr": 0,
"evaluate": "本片讲述利用能检测出人们杀意的装置以及利用思想粒子做出的“井”,来探知事件真相的科幻故事。...",
"areas": [{
"id": 2,
"name": "日本"
}],
"subtitle": "",
"first_ep": 307446,
"can_watch": 1,
"series": {
"series_id": 4760,
"title": "ID:INVADED",
"season_count": 1,
"new_season_id": 29310
},
"publish": {
"pub_time": "2020-01-06 00:30:00",
"pub_time_show": "敬请期待",
"release_date": "2020-01-06",
"release_date_show": "2020年1月6日"
},
"mode": 2,
"section": [{
"section_id": 39327,
"season_id": 29310,
"limit_group": 328,
"watch_platform": 15,
"copyright": "dujia",
"ban_area_show": 1
}, {
"section_id": 39633,
"season_id": 29310,
"limit_group": 328,
"watch_platform": 15,
"type": 1,
"copyright": "dujia",
"title": "其他",
"ban_area_show": 1
}, {
"section_id": 44101,
"season_id": 29310,
"limit_group": 316,
"watch_platform": 15,
"type": 4,
"copyright": "ugc",
"ban_area_show": 1
}],
"url": "https://www.bilibili.com/bangumi/play/ss29310",
"follow_status": 2,
"is_new": 0,
"progress": "",
"both_follow": true
}, {
"season_id": 25739,
"media_id": 139252,
"season_type": 1,
"season_type_name": "番剧",
"title": "关于我转生变成史莱姆这档事",
"cover": "http://i0.hdslb.com/bfs/bangumi/a4c0e0ccc44fe3949a734f546cf5bb07da925bad.png",
"total_count": 27,
"is_finish": 1,
"is_started": 1,
"is_play": 1,
"badge": "会员专享",
"badge_type": 0,
"rights": {
"allow_review": 1,
"is_selection": 1,
"selection_style": 1
},
"stat": {
"follow": 5516519,
"view": 246739631,
"danmaku": 3802465,
"reply": 460225,
"coin": 1338958,
"series_follow": 5516535,
"series_view": 246739631
},
"new_ep": {
"id": 316957,
"index_show": "全27话",
"cover": "http://i0.hdslb.com/bfs/archive/81d07d1a478ce3a6209b557e14df9b9c78c42abb.jpg",
"title": "OAD03",
"long_title": "外传:利姆鲁的华丽教师生活 其一",
"pub_time": "2020-03-27 00:00:03",
"duration": 1493000
},
"rating": {
"score": 9.4,
"count": 83354
},
"square_cover": "http://i0.hdslb.com/bfs/bangumi/8d9f5b4a566d0547bc2e3f6f733b732a09c0d3d4.jpg",
"season_status": 13,
"season_title": "TV",
"badge_ep": "会员",
"media_attr": 0,
"season_attr": 0,
"evaluate": "史莱姆生活,开始了。\n上班族的三上悟在道路上被歹徒给刺杀身亡后,回过神来发现自己转生到了异世界。\n不过,自己居然是“史莱姆”!\n他在得到利姆鲁这个名字后开始了自己的史莱姆人生,随着与各个种族相处交流的...",
"areas": [{
"id": 2,
"name": "日本"
}],
"subtitle": "",
"first_ep": 250460,
"can_watch": 1,
"series": {
"series_id": 4188,
"title": "关于我转生变成史莱姆这档事",
"season_count": 1,
"new_season_id": 25739
},
"publish": {
"pub_time": "2018-10-02 00:30:00",
"pub_time_show": "2018年10月02日00:30",
"release_date": "2018-10-02",
"release_date_show": "2018年10月2日"
},
"mode": 2,
"section": [{
"section_id": 34988,
"season_id": 25739,
"limit_group": 328,
"watch_platform": 15,
"copyright": "bilibili",
"ban_area_show": 1
}],
"url": "https://www.bilibili.com/bangumi/play/ss25739",
"follow_status": 2,
"is_new": 0,
"progress": "",
"both_follow": true
}],
"pn": 1,
"ps": 2,
"total": 25
}
}
查询用户关注的TAG(话题)
请求方式:GET
认证方式:Cookie(SESSDATA)
如设置隐私查看自己的需要认证
带有转义
只显示前100个
url参数:
参数名 | 类型 | 内容 | 必要性 | 备注 |
---|---|---|---|---|
mid | num | 目标用户mid | 必要 |
json回复:
根对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
ststus | bool | 返回值 | false:错误 true:正确 |
data | 错误时:str 正确时:obj |
错误时:错误信息 正确时:数据本体 |
正确时不返回错误信息 |
data
对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
tags | array | 关注TAG列表 | |
count | num | 关注TAG的数 |
data
中的tags
数组:
项 | 类型 | 内容 | 备注 |
---|---|---|---|
0 | obj | 关注TAG1 | |
n | obj | 关注TAG(n+1) | |
…… | obj | …… | …… |
99 | obj | 关注TAG100 | 最后一项 |
data
中的tags
数组中的对象:
字段 | 类型 | 内容 | 备注 |
---|---|---|---|
archive_count | num | 0 | 作用尚不明确 |
cover | str | TAG图片url | 无则为空 |
name | str | TAG名 | |
notify | num | 1 | 作用尚不明确 |
tag_id | num | tag_id | |
updated_ts | str | 1970-01-01 08:00:00 | 作用尚不明确 |
示例:
查询用户mid=2
的关注TAG
curl -G 'http://space.bilibili.com/ajax/tags/getSubList' \
--data-urlencode 'mid=2' \
-b 'SESSDATA=xxx'
查看响应示例:
{
"status": true,
"data": {
"tags": [{
"name": "豪宅",
"cover": "",
"tag_id": 47637,
"notify": 1,
"archive_count": 0,
"updated_ts": "1970-01-01 08:00:00"
}, {
"name": "死亡搁浅",
"cover": "",
"tag_id": 1737239,
"notify": 1,
"archive_count": 0,
"updated_ts": "1970-01-01 08:00:00"
},
…………
],
"count": 58
}
}