bilibili-API-collect/docs/user/relation.md

76 KiB
Raw Blame History

用户关系相关

查询关系列表

关系列表对象

字段 类型 内容 备注
mid num 用户 mid
attribute num 关注属性 0未关注
1已关注
2已关注
6已互粉
128已拉黑
mtime num 关注对方时间 时间戳
互关后刷新
tag 默认分组null
存在至少一个分组array
分组 id
special num 特别关注标志 0
1
contract_info obj
uname str 用户昵称
face str 用户头像url
face_nft num 是否为 NFT 头像 0非 NFT 头像
1NFT 头像
sign str 用户签名
official_verify obj 认证信息
vip obj 会员信息
nft_icon str
rec_reason str
track_id str

数组list中的对象中的tag数组:

类型 内容 备注
0 num 位于分组 1 的分组 id
n num 位于分组n+1的分组 id
…… num …… ……

list中的对象中的official_verify对象:

字段 类型 内容 备注
type num 用户认证类型 -1
1认证
desc str 用户认证信息 无为空

list中的对象中的vip对象:

字段 类型 内容 备注
vipType num 会员类型 0
1月度大会员
2年度以上大会员
vipDueDate num 会员到期时间 时间戳 毫秒
dueRemark str
accessStatus num
vipStatus num 大会员状态 0
1
vipStatusWarn str
themeType num
label obj

vip中的label对象:

字段 类型 内容 备注
path str

查询用户粉丝明细

https://api.bilibili.com/x/relation/followers

请求方式GET

认证方式CookieSESSDATA或 APP

登录可看当前用户前 1000 名,其他用户可查看前 250 名(网页端请求时ps为 20所以直接查看只能看到前 100 名)

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
vmid num 目标用户 mid 必要
ps num 每页项数 非必要 默认为 50
pn num 页码 非必要 默认为 1
其他用户仅可查看前 5 页

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-400请求错误
22007访问超过 5 页
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data对象:

字段 类型 内容 备注
list array 明细列表
re_version num
total num 粉丝总数

data中的list数组:

类型 内容 备注
0 obj 粉丝 1 详见 关系列表对象
n obj 粉丝 n+1 按照添加顺序排列
…… obj …… ……

示例:

获取用户mid=293793435的粉丝明细

curl -G 'https://api.bilibili.com/x/relation/followers' \
    --data-urlencode 'vmid=293793435' \
    --data-urlencode 'ps=2' \
    --data-urlencode 'pn=1' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": {
		"list": [{
			"mid": 387195656,
			"attribute": 0,
			"mtime": 1583839793,
			"tag": null,
			"special": 0,
			"uname": "L_E_M_O_H_E",
			"face": "https://i1.hdslb.com/bfs/face/8ec537db75eeb292faa8dc85a9ff8aba83148c86.jpg",
			"sign": "暂时断更。。Back later",
			"official_verify": {
				"type": -1,
				"desc": ""
			},
			"vip": {
				"vipType": 0,
				"vipDueDate": 0,
				"dueRemark": "",
				"accessStatus": 0,
				"vipStatus": 0,
				"vipStatusWarn": "",
				"themeType": 0,
				"label": {
					"path": ""
				}
			}
		}, {
			"mid": 175989424,
			"attribute": 0,
			"mtime": 1583822019,
			"tag": null,
			"special": 0,
			"uname": "哥本哈根iii",
			"face": "https://i1.hdslb.com/bfs/face/e53c0fe9315176d48bd294b1f381f0da70131cd7.jpg",
			"sign": "",
			"official_verify": {
				"type": -1,
				"desc": ""
			},
			"vip": {
				"vipType": 0,
				"vipDueDate": 0,
				"dueRemark": "",
				"accessStatus": 0,
				"vipStatus": 0,
				"vipStatusWarn": "",
				"themeType": 0,
				"label": {
					"path": ""
				}
			}
		}],
		"re_version": 3857745402,
		"total": 365
	}
}

查询用户关注明细

https://api.bilibili.com/x/relation/followings

请求方式GET

认证方式CookieSESSDATA或 APP

登录可看当前用户全部其他用户仅可查看前5页

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
vmid num 目标用户 mid 必要
order_type str 排序方式 非必要 按照关注顺序排列:留空
按照最常访问排列attention
ps num 每页项数 非必要 默认为 50
pn num 页码 非必要 默认为 1
其他用户仅可查看前 5 页

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-400请求错误
22007访问超过 5 页
22115用户已设置隐私无法查看
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data对象:

字段 类型 内容 备注
list array 明细列表
re_version num
total num 关注总数

data中的list数组:

类型 内容 备注
0 obj 关注1 关系列表对象
n obj 关注n+1 按照添加顺序排列
…… obj …… ……

示例:

获取用户mid=293793435的关注明细,按照关注顺序

curl -G 'https://api.bilibili.com/x/relation/followings' \
    --data-urlencode 'vmid=293793435' \
    --data-urlencode 'order_type=' \
    --data-urlencode 'ps=2' \
    --data-urlencode 'pn=1' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": {
		"list": [{
			"mid": 14082,
			"attribute": 2,
			"mtime": 1584271945,
			"tag": null,
			"special": 0,
			"uname": "山新",
			"face": "https://i0.hdslb.com/bfs/face/74c82caee6d9eb623e56161ea8ed6d68afabfeae.jpg",
			"sign": "都说了是天依爹地,不是妈咪。\r私信有点多回复不过来商业合作啥的请移步Weibo私信@山新 哦哦哦~",
			"official_verify": {
				"type": 0,
				"desc": "配音演员、声优。洛天依声源提供者。"
			},
			"vip": {
				"vipType": 2,
				"vipDueDate": 1601654400000,
				"dueRemark": "",
				"accessStatus": 0,
				"vipStatus": 1,
				"vipStatusWarn": "",
				"themeType": 0,
				"label": {
					"path": ""
				}
			}
		}, {
			"mid": 420831218,
			"attribute": 2,
			"mtime": 1584208169,
			"tag": [207542],
			"special": 0,
			"uname": "支付宝Alipay",
			"face": "https://i2.hdslb.com/bfs/face/aaf18aeb2d9822e28a590bd8d878572ca8c59e04.jpg",
			"sign": "阿支来了,关注点赞转发投币四连走起!",
			"official_verify": {
				"type": 1,
				"desc": "支付宝官方账号"
			},
			"vip": {
				"vipType": 1,
				"vipDueDate": 1585065600000,
				"dueRemark": "",
				"accessStatus": 0,
				"vipStatus": 1,
				"vipStatusWarn": "",
				"themeType": 0,
				"label": {
					"path": ""
				}
			}
		}],
		"re_version": 3228575555,
		"total": 699
	}
}

查询用户关注明细2

https://app.biliapi.net/x/v2/relation/followings

请求方式GET

仅可查看前 5 页,可以获取已设置可见性隐私的关注列表

url参数

参数名 类型 内容 必要性 备注
vmid num 目标用户 mid 必要
order str 排序方式 非必要 按照降序排列desc
按照升序排列asc
默认降序排列
ps num 每页项数 非必要 默认为 50
pn num 页码 非必要 默认为 1
仅可查看前 5 页

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-400请求错误
22007访问超过 5 页
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data对象:

字段 类型 内容 备注
list array 明细列表
re_version num
total num 关注总数

data中的list数组:

类型 内容 备注
0 obj 关注 1 关系列表对象 数据结构不同
n obj 关注n+1 按照添加顺序排列
…… obj …… ……

数组list中的对象:

字段 类型 内容 备注
mid num 用户 mid
attribute num 关注属性 0未关注
2已关注
6已互粉
mtime num 关注对方时间 时间戳
互关后刷新
tag 默认分组null
存在至少一个分组array
分组 id
special num 特别关注标志 0
1
uname str 用户昵称
face str 用户头像 url
sign str 用户签名
official_verify obj 认证信息
vip obj 会员信息
live num 是否直播 0未直播
1直播中

数组list中的对象中的tag数组:

类型 内容 备注
0 num 位于分组 1 的分组 id
n num 位于分组n+1的分组 id
…… num …… ……

list中的对象中的official_verify对象:

字段 类型 内容 备注
type num 用户认证类型 -1
1认证
desc str 用户认证信息 无为空

list中的对象中的vip对象:

字段 类型 内容 备注
vipType num 会员类型 0
1月度大会员
2年度以上大会员
vipDueDate num 会员到期时间 时间戳 毫秒
dueRemark str
accessStatus num
vipStatus num 大会员状态 0
1
vipStatusWarn str
themeType num
label obj

vip中的label对象:

字段 类型 内容 备注
path str

示例:

获取用户mid=293793435的关注明细,按照关注顺序

curl -G 'https://app.biliapi.net/x/v2/relation/followings' \
    --data-urlencode 'vmid=293793435' \
    --data-urlencode 'ps=2' \
    --data-urlencode 'pn=1' \
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": {
		"list": [{
			"mid": 14082,
			"attribute": 2,
			"mtime": 1584271945,
			"tag": null,
			"special": 0,
			"uname": "山新",
			"face": "https://i0.hdslb.com/bfs/face/74c82caee6d9eb623e56161ea8ed6d68afabfeae.jpg",
			"sign": "都说了是天依爹地,不是妈咪。\r私信有点多回复不过来商业合作啥的请移步Weibo私信@山新 哦哦哦~",
			"official_verify": {
				"type": 0,
				"desc": "配音演员、声优。洛天依声源提供者。"
			},
			"vip": {
				"vipType": 2,
				"vipDueDate": 1601654400000,
				"dueRemark": "",
				"accessStatus": 0,
				"vipStatus": 1,
				"vipStatusWarn": "",
				"themeType": 0,
				"label": {
					"path": ""
				}
			}
		}, {
			"mid": 420831218,
			"attribute": 2,
			"mtime": 1584208169,
			"tag": [207542],
			"special": 0,
			"uname": "支付宝Alipay",
			"face": "https://i2.hdslb.com/bfs/face/aaf18aeb2d9822e28a590bd8d878572ca8c59e04.jpg",
			"sign": "阿支来了,关注点赞转发投币四连走起!",
			"official_verify": {
				"type": 1,
				"desc": "支付宝官方账号"
			},
			"vip": {
				"vipType": 1,
				"vipDueDate": 1585065600000,
				"dueRemark": "",
				"accessStatus": 0,
				"vipStatus": 1,
				"vipStatusWarn": "",
				"themeType": 0,
				"label": {
					"path": ""
				}
			}
		}],
		"re_version": 3228575555,
		"total": 699
	}
}

搜索关注明细

https://api.bilibili.com/x/relation/followings/search

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
vmid str 目标用户 mid 必要
name str 搜索关键词 非必要
ps num 每页项数 非必要 默认为 50
pn num 页码 非必要 默认为 1

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-400请求错误
22007访问超过 5 页
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data 对象:

字段 类型 内容 备注
list array 明细列表
re_version num
total num 关注总数

data中的list数组:

类型 内容 备注
0 obj 匹配项目 1 关系列表对象
n obj 匹配项目n+1 按照添加顺序排列
…… obj …… ……

示例:

搜索我的关注列表中关键词warma

curl -G 'https://api.bilibili.com/x/relation/followings/search' \
    --data-urlencode 'vmid=293793435' \
    --data-urlencode 'name=warma' \
    --data-urlencode 'ps=2' \
    --data-urlencode 'pn=1' \
    -b 'SESSDATA=xxx'
查看响应示例: ```json { "code": 0, "message": "0", "ttl": 1, "data": { "list": [ { "mid": 53456, "attribute": 2, "mtime": 1586415053, "tag": [ -10 ], "special": 1, "uname": "Warma", "face": "https://i2.hdslb.com/bfs/face/c1bbee6d255f1e7fc434e9930f0f288c8b24293a.jpg", "sign": "我是沃玛,做点傻开心的视频。日常发在微博:@_warma_ ", "official_verify": { "type": 0, "desc": "bilibili 知名UP主" }, "vip": { "vipType": 2, "vipDueDate": 1637424000000, "dueRemark": "", "accessStatus": 0, "vipStatus": 1, "vipStatusWarn": "", "themeType": 0, "label": { "path": "" } } } ], "total": 1 } } ```

查询共同关注明细

https://api.bilibili.com/x/relation/same/followings

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
vmid num 目标用户 mid 必要
ps num 每页项数 非必要 默认为 50
pn num 页码 非必要 默认为 1

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data 对象:

字段 类型 内容 备注
list array 明细列表
re_version num
total num 关注总数

data中的list数组:

类型 内容 备注
0 obj 共同关注 1 关系列表对象
n obj 共同关注n+1 按照添加顺序排列
…… obj …… ……

示例:

获取自己与用户mid=2的共同关注明细

curl -G 'https://api.bilibili.com/x/relation/same/followings' \
--data-urlencode 'vmid=2' \
--data-urlencode 'ps=2' \
--data-urlencode 'pn=1' \
-b 'SESSDATA=xxx'
查看响应示例:
{
    "code": 0,
    "message": "0",
    "ttl": 1,
    "data": {
        "list": [
            {
                "mid": 116683,
                "attribute": 2,
                "mtime": 1564627532,
                "tag": null,
                "special": 0,
                "uname": "=咬人猫=",
                "face": "https://i0.hdslb.com/bfs/face/8fad84a4470f3d894d8f0dc95555ab8f2cb10a83.jpg",
                "sign": "面瘫女仆酱~小粗腿~事业线什么的!!吐槽你就输了!喵~",
                "official_verify": {
                    "type": 0,
                    "desc": "bilibili 2019百大UP主、高能联盟成员"
                },
                "vip": {
                    "vipType": 2,
                    "vipDueDate": 1618934400000,
                    "dueRemark": "",
                    "accessStatus": 0,
                    "vipStatus": 1,
                    "vipStatusWarn": "",
                    "themeType": 0,
                    "label": {
                        "path": ""
                    }
                }
            },
            {
                "mid": 517717593,
                "attribute": 2,
                "mtime": 1592126052,
                "tag": [
                    207542
                ],
                "special": 0,
                "uname": "上海爱丽丝幻乐团",
                "face": "https://i0.hdslb.com/bfs/face/851a9191cbe93e66304d7577c0f6f83834e52109.jpg",
                "sign": "日本同人社团 上海爱丽丝幻乐团",
                "official_verify": {
                    "type": 0,
                    "desc": "上海爱丽丝幻乐团官方账号"
                },
                "vip": {
                    "vipType": 1,
                    "vipDueDate": 1593792000000,
                    "dueRemark": "",
                    "accessStatus": 0,
                    "vipStatus": 0,
                    "vipStatusWarn": "",
                    "themeType": 0,
                    "label": {
                        "path": ""
                    }
                }
            }
        ],
        "re_version": 2498273968,
        "total": 38
    }
}

查询悄悄关注明细

https://api.bilibili.com/x/relation/whispers

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为0
ttl num 1
data obj 信息本体

data 对象:

字段 类型 内容 备注
list array 明细列表
re_version num

data中的list数组:

类型 内容 备注
0 obj 悄悄关注 1 关系列表对象
n obj 悄悄关注n+1 按照操作顺序排列
…… obj …… ……

示例:

curl -G 'https://api.bilibili.com/x/relation/whispers' \
	-b 'SESSDATA=xxx'
查看响应示例:
{
    "code": 0,
    "message": "0",
    "ttl": 1,
    "data": {
        "list": [
            {
                "mid": 178429408,
                "attribute": 1,
                "mtime": 1605972105,
                "tag": null,
                "special": 0,
                "uname": "老弟一号",
                "face": "https://i2.hdslb.com/bfs/face/21426275f3d3149b96b88783275205ba574c09e3.jpg",
                "sign": "萌新硬件玩家,前垃圾佬~(◦˙▽˙◦某宝店 老弟一号 粉丝群679540094商务合作V13869651328",
                "official_verify": {
                    "type": 0,
                    "desc": "知识领域优质UP主"
                },
                "vip": {
                    "vipType": 2,
                    "vipDueDate": 1632499200000,
                    "dueRemark": "",
                    "accessStatus": 0,
                    "vipStatus": 1,
                    "vipStatusWarn": "",
                    "themeType": 0,
                    "label": {
                        "path": ""
                    }
                }
            }
        ],
        "re_version": 2137574562
    }
}

查询互相关注明细

https://api.bilibili.com/x/relation/friends

请求方式GET

认证方式CookieSESSDATA或 APP

查询与自己互关的用户明细,可看全部

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为0
ttl num 1
data obj 信息本体

data 对象:

字段 类型 内容 备注
list array 明细列表
re_version num

data中的list数组:

类型 内容 备注
0 obj 互关 1 关系列表对象
n obj 互关n+1 按照添加顺序排列
…… obj …… ……

示例:

curl -G 'https://api.bilibili.com/x/relation/friends' \
    -b 'SESSDATA=xxx'
查看响应示例: ```json { "code": 0, "message": "0", "ttl": 1, "data": { "list": [ { "mid": 596000, "attribute": 6, "mtime": 1685110154, "tag": null, "special": 0, "uname": "椛椛在睡觉", "face": "https://i2.hdslb.com/bfs/face/365c1ef3b2a3afe21d6832796338fad5119b2592.jpg", "sign": "欢迎来找椛椛玩~ https://blogs.momiji-jin.com/", "face_nft": 0, "official_verify": { "type": -1, "desc": "" }, "vip": { "vipType": 2, "vipDueDate": 1702742400000, "dueRemark": "", "accessStatus": 0, "vipStatus": 1, "vipStatusWarn": "", "themeType": 0, "label": { "path": "", "text": "年度大会员", "label_theme": "annual_vip", "text_color": "#FFFFFF", "bg_style": 1, "bg_color": "#FB7299", "border_color": "" }, "avatar_subscript": 1, "nickname_color": "#FB7299", "avatar_subscript_url": "" }, "nft_icon": "", "rec_reason": "", "track_id": "" }, { "mid": 24022863, "attribute": 6, "mtime": 1685026230, "tag": [ -10 ], "special": 1, "uname": "黄禄轩电脑专用账号", "face": "https://i0.hdslb.com/bfs/face/a70ec7d2a3822980a915ef4b30371af0cbc79132.jpg", "sign": "若要私信,请私信「黄禄轩手机专用账号」http://space.bilibili.com/17640193/,群:410311648", "face_nft": 0, "official_verify": { "type": -1, "desc": "" }, "vip": { "vipType": 2, "vipDueDate": 1686412800000, "dueRemark": "", "accessStatus": 0, "vipStatus": 1, "vipStatusWarn": "", "themeType": 0, "label": { "path": "", "text": "年度大会员", "label_theme": "annual_vip", "text_color": "#FFFFFF", "bg_style": 1, "bg_color": "#FB7299", "border_color": "" }, "avatar_subscript": 1, "nickname_color": "#FB7299", "avatar_subscript_url": "" }, "nft_icon": "", "rec_reason": "", "track_id": "" }, { "mid": 85438718, "attribute": 6, "mtime": 1684759843, "tag": [ 194110 ], "special": 0, "uname": "忘忧北萱草Official", "face": "https://i2.hdslb.com/bfs/face/68d8cba01aab907dbb2cf2e17074f20947156237.jpg", "sign": "现已加入 OrangeFire 豪华套餐!", "face_nft": 0, "official_verify": { "type": -1, "desc": "" }, "vip": { "vipType": 2, "vipDueDate": 1691683200000, "dueRemark": "", "accessStatus": 0, "vipStatus": 1, "vipStatusWarn": "", "themeType": 0, "label": { "path": "", "text": "年度大会员", "label_theme": "annual_vip", "text_color": "#FFFFFF", "bg_style": 1, "bg_color": "#FB7299", "border_color": "" }, "avatar_subscript": 1, "nickname_color": "#FB7299", "avatar_subscript_url": "" }, "nft_icon": "", "rec_reason": "", "track_id": "" }, { "mid": 41620134, "attribute": 6, "mtime": 1684759649, "tag": null, "special": 0, "uname": "Tiggy_Chan", "face": "https://i0.hdslb.com/bfs/face/8c8d9f43eda207f8cb8503bfdf6cc3802a1cd6c1.jpg", "sign": "此号只发科技类视频娱乐类转至虎子酱233", "face_nft": 0, "official_verify": { "type": -1, "desc": "" }, "vip": { "vipType": 1, "vipDueDate": 1669219200000, "dueRemark": "", "accessStatus": 0, "vipStatus": 0, "vipStatusWarn": "", "themeType": 0, "label": { "path": "", "text": "", "label_theme": "", "text_color": "", "bg_style": 0, "bg_color": "", "border_color": "" }, "avatar_subscript": 0, "nickname_color": "", "avatar_subscript_url": "" }, "nft_icon": "", "rec_reason": "", "track_id": "" }, …… ], "re_version": 0 } } ```

查询黑名单明细

https://api.bilibili.com/x/relation/blacks

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
ps num 每页项数 非必要 默认为 50
pn num 页码 非必要 默认为 1

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data 对象:

字段 类型 内容 备注
list array 明细列表
re_version num
total num 黑名单总计数

data中的list数组:

类型 内容 备注
0 obj 黑名单 1 关系列表对象
n obj 黑名单 n+1 按照添加顺序排列
…… obj …… ……

示例:

获取黑名单明细

curl -G 'https://api.bilibili.com/x/relation/blacks' \
    --data-urlencode 'ps=2' \
    --data-urlencode 'pn=1' \
    -b 'SESSDATA=xxx'
查看响应示例: ```json { "code": 0, "message": "0", "ttl": 1, "data": { "list": [ { "mid": 22179720, "attribute": 128, "mtime": 1603032789, "tag": null, "special": 0, "uname": "咩2016", "face": "https://i0.hdslb.com/bfs/face/41fe435a7e62eae605a5908652f32f3afff2ae74.jpg", "sign": "", "official_verify": { "type": 0, "desc": "" }, "vip": { "vipType": 0, "vipDueDate": 0, "dueRemark": "", "accessStatus": 0, "vipStatus": 0, "vipStatusWarn": "", "themeType": 0, "label": { "path": "" } } }, { "mid": 16174624, "attribute": 128, "mtime": 1603026420, "tag": null, "special": 0, "uname": "其实死亡没有那么痛", "face": "https://i2.hdslb.com/bfs/face/79257f5a2e7194a71337ccca5927afba7706d316.jpg", "sign": "等我,我马上就来", "official_verify": { "type": 0, "desc": "" }, "vip": { "vipType": 0, "vipDueDate": 0, "dueRemark": "", "accessStatus": 0, "vipStatus": 0, "vipStatusWarn": "", "themeType": 0, "label": { "path": "" } } } ], "re_version": 897205356, "total": 2 } } ```

操作关系

操作用户关系

https://api.bilibili.com/x/relation/modify

请求方式POST

认证方式CookieSESSDATA或 APP

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
fid num 目标用户mid 必要
act num 操作代码 必要 操作代码见下表
re_src num 关注来源代码 必要 空间11
视频14
文章115
活动页面222
csrf str CSRF Token位于 Cookie Cookie 方式必要

操作代码act

代码 含义
1 关注
2 取关
3 悄悄关注
4 取消悄悄关注
5 拉黑
6 取消拉黑
7 踢出粉丝

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-102账号被封停
-111csrf校验失败
-400请求错误
22001不能对自己进行此操作
22003用户位于黑名单
message str 错误信息 默认为0
ttl num 1

示例:

关注mid=14082的用户

curl 'https://api.bilibili.com/x/relation/modify' \
    --data-urlencode 'fid=14082' \
    --data-urlencode 'act=1' \
    --data-urlencode 're_src=11' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1
}

批量操作用户关系

https://api.bilibili.com/x/relation/batch/modify

请求方式POST

认证方式CookieSESSDATA或 APP

此接口只支持关注和拉黑操作

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
fids nums 目标用户 mid 列表 必要 每个之间用,间隔
act num 操作代码 必要 同上
仅可为 1 或 5故只能进行批量关注和拉黑
re_src num 关注来源代码 必要 同上
csrf str CSRF Token位于 Cookie Cookie 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-102账号被封停
-111csrf校验失败
-400请求错误
22003用户位于黑名单
message str 错误信息 默认为0
ttl num 1
data obj 数据本体

data对象:

字段 类型 内容 备注
failed_fids array 操作失败的 mid 列表

data中的failed_fids数组:

类型 内容 备注
0 num 操作失败的 mid 1
n num 操作失败的 midn+1
…… num …… ……

示例:

批量关注mid=1,2,3,4,5的用户

curl 'https://api.bilibili.com/x/relation/batch/modify' \
    --data-urlencode 'fid=1,2,3,4,5' \
    --data-urlencode 'act=1' \
    --data-urlencode 're_src=11' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
    "code": 0,
    "message": "0",
    "ttl": 1,
    "data": {
        "failed_fids": []
    }
}

查询关系属性

关系属性对象

字段 类型 内容 备注
mid num 目标用户 mid
attribute num 关系属性 0未关注
2已关注
6已互粉
128已拉黑
mtime num 关注对方时间 时间戳
未关注为 0
tag null默认分组
array存在至少一个分组
分组 id
special num 特别关注标志 0
1

tag数组:

类型 内容 备注
0 num 位于分组 1 的分组
n num 位于分组n+1的分组
…… num …… ……

查询用户与自己关系(仅关注)

https://api.bilibili.com/x/relation

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
fid num 目标用户 mid 必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为0
ttl num 1
data obj 信息本体 详见 关系属性对象

data对象:示例:

可得对于mid=258150656的用户,在2018/10/28 0:51:41时关注,且设为特别关注,并位于为-10分组中

curl -G 'https://api.bilibili.com/x/relation' \
    --data-urlencode 'fid=258150656' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": {
		"mid": 258150656,
		"attribute": 2,
		"mtime": 1540659101,
		"tag": [-10],
		"special": 1
	}
}

查询用户与自己关系(互相关系)

https://api.bilibili.com/x/space/wbi/acc/relation

请求方式GET

认证方式CookieSESSDATA或 APP

鉴权方式:Wbi 签名

该接口的旧版 API https://api.bilibili.com/x/space/acc/relation(已废弃,不建议使用)

url参数

参数名 类型 内容 必要性 备注
access_key str APP登录Token APP方式必要
mid num 目标用户mid 必要
w_rid str Wbi 签名 必要 详见 Wbi 签名
wts num 当前时间戳 必要 详见 Wbi 签名

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为0
ttl num 1
data obj 信息本体

data对象:

字段 类型 内容 备注
relation obj 目标用户对于当前用户的关系 详见 关系属性对象
be_relation obj 当前用户对于目标用户的关系 详见 关系属性对象

示例:

可得对于mid=15858903的用户,在2019/1/24 14:24:19时关注了对方,且互相关注,自己将对方特别关注,并同时位于为-10194110的分组中,对方也将自己设为特别关注,并同时位于为-1056502的分组中(虽然我看不到)

Wbi 签名的 wtsw_rid生成方式详见 Wbi 签名 文档

curl -G 'https://api.bilibili.com/x/space/acc/relation' \
    --data-urlencode 'mid=15858903' \
    --data-urlencode 'wts=1686015899' \
    --data-urlencode 'w_rid=e10a3c566c9be80a7cebe7bcdf262588' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
    "code": 0,
    "message": "0",
    "ttl": 1,
    "data": {
        "relation": {
            "mid": 15858903,
            "attribute": 6,
            "mtime": 1548311059,
            "tag": [
                -10,
                194110,
                248468
            ],
            "special": 1
        },
        "be_relation": {
            "mid": 293793435,
            "attribute": 6,
            "mtime": 1548311059,
            "tag": [
                56502,
                -10
            ],
            "special": 1
        }
    }
}

批量查询用户与自己关系

https://api.bilibili.com/x/relation/relations

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
fids nums 目标用户 mid 必要 每个之间用,间隔

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为0
ttl num 1
data obj 信息本体

data对象:

字段 类型 内容 备注
{用户mid} obj 关注的用户 详见 关系属性对象
…… obj …… 下同

示例:

批量查询mid=1,2,3,4,5的关系

curl -G 'https://api.bilibili.com/x/relation/relations' \
--data-urlencode 'fid=258150656' \
-b 'SESSDATA=xxx'
查看响应示例:
{
    "code": 0,
    "message": "0",
    "ttl": 1,
    "data": {
        "1": {
            "mid": 1,
            "attribute": 2,
            "mtime": 1601654227,
            "tag": null,
            "special": 0
        },
        "2": {
            "mid": 2,
            "attribute": 2,
            "mtime": 1601654225,
            "tag": null,
            "special": 0
        }
    }
}

关注分组相关

分组 id 特殊值:

id 含义
0 默认分组
-10 特别关心

查询关注分组列表

https://api.bilibili.com/x/relation/tags

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
message str 错误信息 默认为 0
ttl num 1
data array 分组列表

data数组:

类型 内容 备注
1 obj 分组 1
n obj 分组n+1
…… num …… ……

数组data中的对象:

字段 类型 内容 备注
tagid num 分组 id -10特别关注
0默认分组
name str 分组名称
count num 分组成员数
tip str 提示信息

示例:

查询所有的分组的名字以及id

curl 'https://api.bilibili.com/x/relation/tags' \
	-b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": [
         {
            "tagid": -10,
            "name": "特别关注",
            "count": 19,
            "tip": "第一时间收到该分组下用户更新稿件的通知"
        },
        {
            "tagid": 0,
            "name": "默认分组",
            "count": 340,
            "tip": ""
        },
        {
            "tagid": 194110,
            "name": "基友们",
            "count": 127,
            "tip": ""
        },
        {
            "tagid": 194111,
            "name": "我的同学",
            "count": 22,
            "tip": ""
        },
	…………
	]
}

查询关注分组明细

https://api.bilibili.com/x/relation/tag

请求方式GET

认证方式CookieSESSDATA或 APP

只可查询属于自己的分组

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
tagid num 分组 id 必要
order_type str 排序方式 非必要 按照关注顺序排列:留空
按照最常访问排列attention
ps num 每页项数 非必要 默认为 20
pn num 页数 非必要 默认为1

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
22104该分组不存在
message str 错误信息 默认为 0
ttl num 1
data array 成员列表

data数组:

类型 内容 备注
0 obj 成员信息 1 关系列表对象
n obj 成员信息n+1 按照添加顺序排序
…… obj …… ……

data 中的对象:

字段 类型 内容 备注
mid num 用户id
attribute num 0
tag null null
special num 0
contract_info json 空的
uname str 用户名
face str 头像地址
sign str 个人简介
face_nft int ntf头像
official_verify json 官方认证 具体见下
vip json 大会员 参考大会员文档
live json 直播状态 具体见下
nft_icon str 显示nft角标
rec_reason str
track_id str

data对象中的official_verify

字段 类型 内容 备注
type num 0
desc str 官方认证内容

data对象中的live

字段 类型 内容 备注
live_status num 0或1 0未开播1已直播
jump_url str 直播链接

示例:

以每页2项的方式获取了id为207542分组的第1页的粉丝明细按照关注顺序

curl -G 'https://api.bilibili.com/x/relation/tag' \
    --data-urlencode 'tagid=207542' \
    --data-urlencode 'order_type=' \
    --data-urlencode 'ps=2' \
    --data-urlencode 'pn=1' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": [{
		"mid": 420831218,
		"uname": "支付宝Alipay",
		"face": "https://i2.hdslb.com/bfs/face/aaf18aeb2d9822e28a590bd8d878572ca8c59e04.jpg",
		"sign": "阿支来了,关注点赞转发投币四连走起!",
		"official_verify": {
			"type": 1,
			"desc": "支付宝官方账号"
		},
		"vip": {
			"vipType": 1,
			"vipDueDate": 1585065600000,
			"dueRemark": "",
			"accessStatus": 0,
			"vipStatus": 1,
			"vipStatusWarn": "",
			"themeType": 0,
			"label": {
				"path": ""
			}
		}
	}, {
		"mid": 125086406,
		"uname": "MSI微星科技",
		"face": "https://i1.hdslb.com/bfs/face/a844760e4e491677615b39399bc761e74c579bb4.jpg",
		"sign": "你好这里是微星显卡官方专注显卡三十年欢迎私信咨询或提问MSI",
		"official_verify": {
			"type": 1,
			"desc": "微星科技官方账号"
		},
		"vip": {
			"vipType": 1,
			"vipDueDate": 1540656000000,
			"dueRemark": "",
			"accessStatus": 0,
			"vipStatus": 0,
			"vipStatusWarn": "",
			"themeType": 0,
			"label": {
				"path": ""
			}
		}
	}]
}

查询目标用户所在的分组

https://api.bilibili.com/x/relation/tag/user

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
fid num 目标用户 mid 必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
-400请求错误
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data对象:

字段 类型 内容 备注
{加入的分组 id} str 分组名称 若目标用户存在默认分组中,则不显示
…… str …… 下同

示例:

查询用户mid=319214221存在的所有分组和名称

curl -G 'https://api.bilibili.com/x/relation/tag/user' \
    --data-urlencode 'fid=319214221' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": {
		"-10": "特别关注",
		"194111": "我的同学"
	}
}

查询所有特别关注 mid

https://api.bilibili.com/x/relation/tag/special

请求方式GET

认证方式CookieSESSDATA或 APP

url参数

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-101账号未登录
message str 错误信息 默认为 0
ttl num 1
data array 成员列表

data数组:

类型 内容 备注
0 num 成员 1 mid
n num 成员n+1mid
…… num …… ……

示例:

curl 'https://api.bilibili.com/x/relation/tag/special' \
	-b 'SESSDATA=xxx'
查看响应示例:
{
    "code": 0,
    "message": "0",
    "ttl": 1,
    "data": [
        500716647,
        32832243,
        53456,
        25944552,
        301839556,
        427494870,
        319214221,
        31949159,
        382666849,
        258318451,
        15858903,
        54992199,
        3379951,
        392279807,
        23215368,
        258150656,
        20165629,
        22179720
    ]
}

创建分组

https://api.bilibili.com/x/relation/tag/create

请求方式POST

认证方式CookieSESSDATA或 APP

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
tag str 分组名 必要 最长 16 字符
csrf str CSRF Token位于 Cookie Cookie 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-111csrf校验失败
-101账号未登录
-400请求错误
22106该分组已经存在
22103分组名过长
message str 错误信息 默认为 0
ttl num 1
data obj 信息本体

data对象:

字段 类型 内容 备注
tagid num 创建的分组的 id

示例:

创建了名为测试的分组得到id为216677

curl 'https://api.bilibili.com/x/relation/tag/create' \
    --data-urlencode 'tag=测试' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1,
	"data": {
		"tagid": 216677
	}
}

重命名分组

https://api.bilibili.com/x/relation/tag/update

请求方式POST

认证方式CookieSESSDATA或 APP

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
tagid num 分组 id 必要
name str 新名称 必要 最长 16 字符
csrf str CSRF Token位于 Cookie Cookie 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-111csrf校验失败
-101账号未登录
-400请求错误
22103分组名过长
22104该分组不存在
message str 错误信息 默认为 0
ttl num 1

示例:

把id为194112的分组更名为膜法师

curl 'https://api.bilibili.com/x/relation/tag/update' \
    --data-urlencode 'tagid=194112' \
    --data-urlencode 'name=膜法师' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1
}

删除分组

https://api.bilibili.com/x/relation/tag/del

请求方式POST

认证方式CookieSESSDATA或 APP

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
tagid num 分组 id 必要
csrf str CSRF Token位于 Cookie Cookie 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-111csrf校验失败
-101账号未登录
-400请求错误
message str 错误信息 默认为 0
ttl num 1

示例:

删除分组id为216699的分组

curl 'https://api.bilibili.com/x/relation/tag/del' \
    --data-urlencode 'tagid=216699' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1
}

修改分组成员

https://api.bilibili.com/x/relation/tags/addUsers

请求方式POST

认证方式CookieSESSDATA或 APP

如需删除分组中的成员,请将tagids设为 0即移动至默认分组而不是取关

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
fids nums 目标用户 mid 列表 必要 每个之间用,间隔
tagids nums 分组 id 列表 必要 每个之间用,间隔
csrf str CSRF Token位于 Cookie Cookie 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-111csrf校验失败
-101账号未登录
-400请求错误
22104无权限
22105未关注
message str 错误信息 默认为 0
ttl num 1

示例:

把关注用户mid=205631797同时添加分组关系到id为-10207542的分组中

curl 'https://api.bilibili.com/x/relation/tags/addUsers' \
    --data-urlencode 'fids=205631797' \
    --data-urlencode 'tagids=-10,207542' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
	"code": 0,
	"message": "0",
	"ttl": 1
}

复制关注到分组

https://api.bilibili.com/x/relation/tags/copyUsers

请求方式POST

认证方式CookieSESSDATA或 APP

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
fids nums 待复制的用户 mid 列表 必要 每个之间用,间隔
tagids nums 目标分组 id 列表 必要 每个之间用,间隔
csrf str CSRF Token位于 Cookie Cookie 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-111csrf校验失败
-101账号未登录
-400请求错误
22104无权限
22105未关注
message str 错误信息 默认为 0
ttl num 1

示例:

把关注用户mid=4856007mid=326499679同时复制到为231305的分组id中

curl 'https://api.bilibili.com/x/relation/tags/copyUsers' \
    --data-urlencode 'fids=4856007,326499679' \
    --data-urlencode 'tagids=231305' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
    "code":0,
    "message":"0",
    "ttl":1
}

移动关注到分组

https://api.bilibili.com/x/relation/tags/moveUsers

请求方式POST

认证方式CookieSESSDATA或 APP

正文参数application/x-www-form-urlencoded

参数名 类型 内容 必要性 备注
access_key str APP 登录 Token APP 方式必要
beforeTagids nums 原分组 id 列表 必要 每个之间用,间隔
afterTagids nums 新分组 id 列表 必要 每个之间用,间隔
fids nums 待移动的用户 mid 列表 必要 每个之间用,间隔
csrf str CSRF Token位于 Cookie Cookie 方式必要

json回复

根对象:

字段 类型 内容 备注
code num 返回值 0成功
-111csrf校验失败
-101账号未登录
-400请求错误
22104无权限
22105未关注
message str 错误信息 默认为 0
ttl num 1

示例:

把关注用户mid=321173469mid=327086920同时从id为207542的分组移动到为231305的分组中

curl 'https://api.bilibili.com/x/relation/tags/moveUsers' \
    --data-urlencode 'beforeTagids=207542' \
    --data-urlencode 'afterTagids=23130' \
    --data-urlencode 'fids=321173469,327086920' \
    --data-urlencode 'csrf=xxx' \
    -b 'SESSDATA=xxx'
查看响应示例:
{
    "code":0,
    "message":"0",
    "ttl":1
}