直播回放

注: 直播回放相关接口较新,随时可能出现变化。

获取直播回放列表

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorGetReplayList

请求方法: GET

认证方式: Cookie (SESSDATA)

只能获取自己14天的回放,详细信息请查看对应页面open in new window

url参数:

参数名类型内容必要性备注
pagenum页码非必要默认第1页
page_sizenum每页内容数量非必要默认30项,最大30项

json回复:

根对象:

字段类型内容备注
codenum返回值0:成功
-101:未登录
messagestr提示信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
replay_infoarr回放信息列表无结果时为null
paginationobj分页信息
archive_flagbool(?)作用尚不明确
can_editnum(?)作用尚不明确

data.replay_info 数组中的对象:

字段类型内容备注
replay_idnum直播回放id
live_infoobj直播信息
video_infoobj回放视频信息
alarm_infoobj警报信息
room_idnum直播间id
live_keystr标记直播场次的key
start_timenum直播开始秒时间戳调用开始直播接口的时间
end_timenum直播结束秒时间戳调用关闭直播接口的时间

data.replay_info[i].live_info 对象:

字段类型内容备注
titlestr直播标题直播结束时的标题
coverstr直播封面
live_timenum直播时间data.replay_info[i].start_time
live_typenum直播类型?作用尚不明确

data.replay_info[i].video_info 对象:

字段类型内容备注
replay_statusnum回放状态作用尚不明确
estimated_timestr直播回放合成结束时间未合成时为"1970-01-01 08:00:00"
durationnum直播时长单位秒
download_urlstr下载链接片段整场直播回放合成成功时存在
建议通过请求整场直播回放下载链接来获取下载链接
alert_codenum快速检查警告代码整场直播回放合成失败时不存在
alert_messagestr快速检查警告信息整场直播回放合成失败时不存在

data.replay_info[i].alarm_info 对象:

字段类型内容备注
codenum回放合成警报代码
messagestr回放合成错误信息
cur_timenum当前时间戳Unix秒时间戳
is_ban_publishbool是否禁止发布?

data.pagination 对象:

字段类型内容备注
pagenum请求的页码
page_sizenum内容数量
totalnum总计内容数量

示例:

获取自己直播回放列表的第1页,每页2项

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorGetReplayList?page=1&page_size=2' \
  -b 'SESSDATA=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "replay_info": [
      {
        "replay_id": 10707737,
        "live_info": {
          "title": "摆",
          "cover": "https://i0.hdslb.com/bfs/live/59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png",
          "live_time": 1747509268,
          "live_type": 1
        },
        "video_info": {
          "replay_status": 2,
          "estimated_time": "1970-01-01 08:00:00",
          "duration": 1820,
          "alert_code": 2,
          "alert_message": "录像时长远小于开播时长,请关注直播时网络状况"
        },
        "alarm_info": {
          "code": 2,
          "message": "录像生成失败,请稍后再试",
          "cur_time": 1747557808,
          "is_ban_publish": false
        },
        "room_id": 18992371,
        "live_key": "609043243693510451",
        "start_time": 1747509268,
        "end_time": 1747511088
      },
      {
        "replay_id": 10707664,
        "live_info": {
          "title": "摆",
          "cover": "https://i0.hdslb.com/bfs/live/59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png",
          "live_time": 1747508293,
          "live_type": 1
        },
        "video_info": {
          "replay_status": 2,
          "estimated_time": "1970-01-01 08:00:00",
          "duration": 206,
          "alert_code": 2,
          "alert_message": "录像时长远小于开播时长,请关注直播时网络状况"
        },
        "alarm_info": {
          "code": 2,
          "message": "录像生成失败,请稍后再试",
          "cur_time": 1747557808,
          "is_ban_publish": false
        },
        "room_id": 18992371,
        "live_key": "609041817764368179",
        "start_time": 1747508293,
        "end_time": 1747508499
      }
    ],
    "pagination": {
      "page": 1,
      "page_size": 2,
      "total": 29
    },
    "archive_flag": false,
    "can_edit": 1
  }
}

获取已发布片段的信息

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorGetVideoSliceList

请求方式: GET

认证方式: Cookie (SESSDATA)

url参数:

参数名类型内容必要性备注
pagenum页码非必要默认第1页
page_sizenum每页内容数量非必要默认20项,最大20项

json回复:

根对象:

字段类型内容备注
codenum返回值0:成功
-101:未登录
messagestr提示信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
listarr切片信息
pagenum请求的页码
page_sizenum内容数量
totalnum总计内容数量

data.list 数组中的对象:

字段类型内容备注
silce_idnum切片id
av_titlestr切片标题
av_coverstr切片封面
av_statusnum切片状态1:发布中
2:已投稿
3:投稿失败
avidnum切片视频的avid状态为2时存在
ctimestr切片创建时间
start_tmstr切片开始时间
end_tmstr切片结束时间
av_durationnum切片时长状态为2且创作中心出现有效视频时长时存在
failed_reasonstr失败原因状态为3时存在,2024-09-01前发布失败的切片可能不存在
live_typenum(?)作用尚不明确
cnt_playnum播放数视频有播放时存在;若该页出现任意状态不为2的项也会不存在
cnt_danmakunum弹幕数视频有弹幕时存在;若该页出现任意状态不为2的项也会不存在

示例:

获取自己第1页的已发布片段信息,每页3项

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorGetVideoSliceList?page=1&page_size=3' \
  -b 'SESSDATA=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "list": [
      {
        "slice_id": 882357,
        "av_title": "2025051720 error",
        "av_cover": "https://i0.hdslb.com/bfs/live/59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png",
        "av_status": 1,
        "ctime": "2025-05-18 18:13:13",
        "start_tm": "2025-05-17 21:07:04",
        "end_tm": "2025-05-17 21:16:00",
        "live_type": 1
      },
      {
        "slice_id": 879189,
        "av_title": "2025051721 zzz 0",
        "av_cover": "https://i0.hdslb.com/bfs/live/59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png",
        "av_status": 3,
        "ctime": "2025-05-18 00:32:52",
        "start_tm": "2025-05-17 21:07:34",
        "end_tm": "2025-05-17 23:02:03",
        "failed_reason": "duration_false",
        "live_type": 1
      },
      {
        "slice_id": 876259,
        "av_title": "202505171449",
        "av_cover": "https://i0.hdslb.com/bfs/live/59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png",
        "av_status": 2,
        "avid": 114521830065531,
        "ctime": "2025-05-17 14:49:18",
        "start_tm": "2025-05-17 14:19:36",
        "end_tm": "2025-05-17 14:23:48",
        "av_duration": 341,
        "live_type": 1
      }
    ],
    "page": 1,
    "page_size": 3,
    "total": 347
  }
}

获取回放剪辑草稿列表

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetDraftList

请求方法: GET

认证方式: Cookie (SESSDATA)

url参数:

参数名类型内容必要性备注
pagenum页码非必要默认第1页
page_sizenum每页内容数量非必要默认30项,最大30项

json回复:

根对象:

字段类型内容备注
codenum返回值-101:未登录
0:成功
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
draft_infoarr草稿信息无结果时为null
paginationobj分页信息

data.draft_info 数组中的对象:

字段类型内容备注
idnum回放剪辑id
titlestr回放剪辑标题
coverstr回放剪辑封面有封面时存在;若不存在将使用 https://s1.hdslb.com/bfs/static/blive/blfe-link-center/static/img/default.187078d.png
live_keystr标记直播场次的key
ctimestr回放剪辑创建时间
live_start_timestr直播开始时间
live_end_timestr直播结束时间
live_typenum(?)作用尚不明确

data.pagination 对象:

字段类型内容备注
pagenum请求的页码
page_sizenum内容数量
totalnum总计内容数量

示例:

请求自己的回放剪辑草稿列表

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetDraftList?page=1&page_size=12' \
  -b 'SESSDATA=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "draft_info": [
      {
        "id": 988275,
        "title": "直播场次 2025-05-19 20:45:04",
        "live_key": "609431465787395891",
        "ctime": "2025-05-22 01:08:20",
        "live_start_time": "2025-05-19 20:45:04",
        "live_end_time": "2025-05-20 09:40:13",
        "live_type": 1
      },
      {
        "id": 987665,
        "title": "直播场次 2025-05-19 20:45:04 切片",
        "cover": "http://i0.hdslb.com/bfs/live/9bdf1df3d823734c59382120a9a7c10b177dbefd.png",
        "live_key": "609431465787395891",
        "ctime": "2025-05-21 20:28:48",
        "live_start_time": "2025-05-19 20:45:04",
        "live_end_time": "2025-05-20 09:40:13",
        "live_type": 1
      }
    ],
    "pagination": {
      "page": 1,
      "page_size": 30,
      "total": 2
    }
  }
}

删除某个回放剪辑草稿

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/DeleteSliceDraft

请求方法: POST

认证方式: Cookie (SESSDATA)

鉴权方式: Cookie中bili_jct的值正确并与csrf相同

正文参数( application/x-www-form-urlencoded ):

参数名类型内容必要性备注
draft_idnum回放剪辑id必要
csrf_tokenstrCSRF Token(位于cookie)非必要
csrfstrCSRF Token(位于cookie)必要

json回复:

根对象:

字段类型内容备注
codenum返回值-400:参数错误
-101:未登录
-111:csrf校验失败
0:成功
206:无可操作草稿
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
codenum0
messagestr""

示例:

删除回放剪辑id为988275的草稿

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/DeleteSliceDraft' \
  --data-urlencode 'draft_id=988275' \
  --data-urlencode 'csrf=xxx'
  -b 'SESSDATA=xxx;bili_jct=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "code": 0,
    "message": ""
  }
}

请求整场直播回放下载链接

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorVideoDownload

请求方法: POST

认证方式: Cookie (SESSDATA)

鉴权方式: Cookie中bili_jct的值正确并与csrf相同

未生成整场直播回放时将进行生成。

正文参数( application/x-www-form-urlencoded ):

参数名类型内容必要性备注
record_idnum直播回放id必要(可选)record_idlive_key必选其一
live_keystr标记直播场次的key必要(可选)record_idlive_key必选其一
csrf_tokenstrCSRF Token(位于cookie)非必要
csrfstrCSRF Token(位于cookie)必要

json回复:

根对象:

字段类型内容备注
codenum返回值-101:未登录
-111:csrf校验失败
0:成功
100:非法参数
210:回放id或场次key无效
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
recordobj回放状态
download_urlstr回放下载链接完成时存在
download_url_listarr回放下载链接列表完成时存在

data.record 对象:

字段类型内容备注
uidnum用户mid
record_idnum直播回放id
statusnum回放状态
estimated_timenum预计结束时间Unix秒时间戳
current_timenum当前时间Unix秒时间戳
merge_timenum开始合并时间Unix秒时间戳
toaststr提示信息失败时存在

data.download_url_list 数组:

类型内容备注
0str回放下载链接

示例:

请求回放id为10597910的下载链接

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorVideoDownload' \
  --data-urlencode 'record_id=10597910' \
  --data-urlencode 'live_key=607942821532667699' \
  --data-urlencode 'csrf=xxx' \
  -b 'SESSDATA=xxx;bili_jct=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "record": {
      "uid": 438160221,
      "record_id": 10597910,
      "status": 30,
      "estimated_time": 1747639543,
      "current_time": 1747639106,
      "merge_time": 1747638665
    },
    "download_url": "https://upos-sz-mirrorali.bilivideo.com/ugcever/n250519sa3hkpirw61hjskuit4d9fdsj.mp4?deadline=1747682306&gen=record2vod&os=upos&trid=da40b42594d5446da29cb0d2b2f25f45&uparams=deadline,gen,os,trid&upsig=c6ac5f218af40b2c120b3f5add2e4d6b&attname=直播回放_2025-05-13_20-49-04.mp4",
    "download_url_list": [
      "https://upos-sz-mirrorali.bilivideo.com/ugcever/n250519sa3hkpirw61hjskuit4d9fdsj.mp4?deadline=1747682306&gen=record2vod&os=upos&trid=da40b42594d5446da29cb0d2b2f25f45&uparams=deadline,gen,os,trid&upsig=c6ac5f218af40b2c120b3f5add2e4d6b&attname=直播回放_2025-05-13_20-49-04.mp4"
    ]
  }
}

获取回放的信息

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetAnchorVideoUidRecordsSubsect

请求方法: GET

认证方式: Cookie (SESSDATA)

url参数:

参数名类型内容必要性备注
record_idnum直播回放id必要

json回复:

根对象:

字段类型内容备注
codenum返回值-400:参数错误
-101:未登录
0:成功
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体失败时不可用

data 对象:

字段类型内容备注
listarr回放信息列表

data.list 数组中的对象:

字段类型内容备注
uidnum用户mid
record_idnum直播回放id
titlestr直播标题
coverstr直播封面
statusnum回放状态
start_timenum直播开始时间Unix秒时间戳
end_timenum直播结束时间Unix秒时间戳

示例:

获取回放id为10707664的信息

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetAnchorVideoUidRecordsSubsect?record_id=10707664' \
  -b 'SESSDATA=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "list": [
      {
        "uid": 438160221,
        "record_id": 10707664,
        "title": "摆",
        "cover": "https://i0.hdslb.com/bfs/live/59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png",
        "status": 2,
        "start_time": 1747508293,
        "end_time": 1747508499
      }
    ]
  }
}

轮询回放合成状态

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetAnchorVideoUidRecord

请求方法: POST

认证方式: Cookie (SESSDATA)

鉴权方式: Cookie中bili_jct的值正确并与csrf相同

正文参数( application/x-www-form-urlencoded ):

参数名类型内容必要性备注
recordsstr直播回放id列表必要,分隔
csrf_tokenstrCSRF Token(位于cookie)非必要
csrfstrCSRF Token(位于cookie)必要

json回复:

根对象:

字段类型内容备注
codenum返回值-101:未登录
-400:参数错误
0:成功
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
listarr查询结果无效的id会被忽略

data.list 数组中的对象:

字段类型内容备注
uidnum用户mid
record_idnum直播回放id
statusnum回放状态
current_timenum当前时间戳Unix秒时间戳
estimated_timenum预计结束时间戳初次请求回放下载链接后存在
merge_timenum合成开始时间戳初次请求回放下载链接后存在

示例:

查询各种回放id

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetAnchorVideoUidRecord' \
  --data-urlencode 'records=10727160,10597910,10687720,10230000,99999999' \
  --data-urlencode 'csrf=xxx' \
  -b 'SESSDATA=xxx;bili_jct=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "list": [
      {
        "uid": 91089731,
        "record_id": 10230000,
        "status": 2,
        "current_time": 1747641604
      },
      {
        "uid": 438160221,
        "record_id": 10597910,
        "status": 30,
        "estimated_time": 1747639543,
        "current_time": 1747641604,
        "merge_time": 1747638665
      },
      {
        "uid": 438160221,
        "record_id": 10687720,
        "status": -30,
        "estimated_time": 1747635525,
        "current_time": 1747641604,
        "merge_time": 1747635486,
        "toast": "因直播过程中存在推流质量问题(网络波动或丢包),本场直播回放无法合成"
      },
      {
        "uid": 3493299121817771,
        "record_id": 10727160,
        "status": 2,
        "current_time": 1747641604
      }
    ]
  }
}

获取切片视频流

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetSliceStream

请求方法: GET

认证方式: Cookie (SESSDATA)

url参数:

参数名类型内容必要性备注
live_keystr标记直播场次的key必要对应获取直播回放列表data.replay_info[i].live_key
start_timenum直播开始时间戳必要对应获取直播回放列表data.replay_info[i].start_time
end_timenum直播结束时间戳必要对应获取直播回放列表data.replay_info[i].end_time
web_locationstr(?)非必要

json回复:

根对象:

字段类型内容备注
codenum返回值-400:参数缺失
-101:未登录
0:成功
100:非法参数
202:场次无效
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
listarr直播回放视频列表如果该场回放没有视频流将为null

data.list 数组中的对象:

字段类型内容备注
start_timenum片段开始时间戳Unix秒时间戳
end_timenum片段结束时间戳Unix秒时间戳
streamstr直播回放视频流
typenum类型?2:一般回放?

示例:

获取某个场次的视频流

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetSliceStream?live_key=607113721045847859&start_time=1746863101&end_time=1746879299' \
  -b 'SESSDATA=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "list": [
      {
        "start_time": 1746863103,
        "end_time": 1746879246,
        "stream": "https://bvc-live.bilivideo.com/hls-record-gateway/videoPlay?biz_id=live2vod-clip&end_time=1746879246&header_name=1746863103.m4s&host_id=edge-hls-bvc-self-cn-jsyz-ct-03-59-6d854b4bd8-gnlb7&no_end=0&schema=https&sign=12f649dd540096672745d60b84f18eda&start_time=1746863103&stream_name=live_438160221_32373699&ts=1752930893&version=2",
        "type": 2
      },
      {
        "start_time": 1746879267,
        "end_time": 1746879269,
        "stream": "https://bvc-live.bilivideo.com/hls-record-gateway/videoPlay?biz_id=live2vod-clip&end_time=1746879269&header_name=1746863104.m4s&host_id=edge-hls-bvc-self-cn-jsyz-ct-03-59-6d854b4bd8-gnlb7&no_end=0&schema=https&sign=5c63605f1fa88561a6257b6812725b4f&start_time=1746879267&stream_name=live_438160221_32373699&ts=1752930893&version=2",
        "type": 2
      },
      {
        "start_time": 1746879269,
        "end_time": 1746879298,
        "stream": "https://bvc-live.bilivideo.com/hls-record-gateway/videoPlay?biz_id=live2vod-clip&end_time=1746879298&header_name=1746863105.m4s&host_id=edge-hls-bvc-self-cn-jsyz-ct-03-59-6d854b4bd8-gnlb7&no_end=0&schema=https&sign=70929627354f4380b54b97fcdb69c8a2&start_time=1746879269&stream_name=live_438160221_32373699&ts=1752930893&version=2",
        "type": 2
      }
    ]
  }
}

获取直播会话数据

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetLiveSessionData

请求方法: GET

认证方式: Cookie (SESSDATA)

url参数:

参数名类型内容必要性备注
live_keystr标记直播场次的key必要
start_tmstr开始时间必要格式为yyyy-mm-dd+HH:MM:SS,时区为UTC+08:00(中国标准时间);取值对实际无影响
end_tmstr开始时间必要格式为yyyy-mm-dd+HH:MM:SS,时区为UTC+08:00(中国标准时间);取值对实际无影响
web_locationstr(?)

json回复:

根对象:

字段类型内容备注
codenum返回值-500:服务器错误
-101:未登录
0:成功
100:非法参数
202:场次无效
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
session_dataarr会话数据
max_danmakunum弹幕最多的时间戳Unix秒时间戳,没有则为0
max_pcunum进房最多的时间戳Unix秒时间戳,没有则为0
max_valuenum(?)效果未知
high_light_dataarr高光时刻数据
ass_urlstrASS字幕链接用作弹幕显示

data.session_data 数组中的对象:

字段类型内容备注
tsnum采样时间Unix秒时间戳
valuenum弹幕数量

data.high_light_data 数组中的对象:

字段类型内容备注
idnum高光id
typenum高光类型1:弹幕
2:进房
start_timenum高光开始时间戳Unix秒时间戳
end_timenum高光结束时间戳Unix秒时间戳
titlestr高光提示标题
coverstr(?)目前为""
extrastr(?)目前为""

示例:

获取场次key为607113721045847859的会话数据

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetLiveSessionData?live_key=607113721045847859&start_tm=0000-01-01+00:00:00&end_tm=1970-01-01+00:00:00' \
  -b 'SESSDATA=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "session_data": [
      {
        "ts": 1746863100,
        "value": 0
      },
      {
        "ts": 1746863160,
        "value": 0
      },
      {
        "ts": 1746863220,
        "value": 0
      },
      {
        "ts": 1746863280,
        "value": 0
      },
      {
        "ts": 1746863340,
        "value": 0
      },
      {
        "ts": 1746863400,
        "value": 0
      },
      {
        "ts": 1746863460,
        "value": 0
      },
      {
        "ts": 1746863520,
        "value": 0
      },
      {
        "ts": 1746863580,
        "value": 0
      },
      {
        "ts": 1746863640,
        "value": 0
      },
      {
        "ts": 1746863700,
        "value": 0
      },
      {
        "ts": 1746863760,
        "value": 0
      },
      {
        "ts": 1746863820,
        "value": 0
      },
      // 省略100多条数据
      {
        "ts": 1746878520,
        "value": 0
      },
      {
        "ts": 1746878580,
        "value": 0
      },
      {
        "ts": 1746878640,
        "value": 0
      },
      {
        "ts": 1746878700,
        "value": 0
      },
      {
        "ts": 1746878760,
        "value": 0
      },
      {
        "ts": 1746878820,
        "value": 0
      },
      {
        "ts": 1746878880,
        "value": 0
      },
      {
        "ts": 1746878940,
        "value": 0
      },
      {
        "ts": 1746879000,
        "value": 0
      },
      {
        "ts": 1746879060,
        "value": 0
      },
      {
        "ts": 1746879120,
        "value": 0
      },
      {
        "ts": 1746879180,
        "value": 0
      },
      {
        "ts": 1746879240,
        "value": 0
      }
    ],
    "max_danmaku": 1746864660,
    "max_pcu": 1746864660,
    "max_value": 0,
    "high_light_data": [
      {
        "id": 6226272,
        "type": 1,
        "start_time": 1746873300,
        "end_time": 1746873480,
        "title": "弹幕高光 Top 1",
        "cover": "",
        "extra": ""
      },
      {
        "id": 6226274,
        "type": 1,
        "start_time": 1746873120,
        "end_time": 1746873420,
        "title": "弹幕高光 Top 2",
        "cover": "",
        "extra": ""
      },
      {
        "id": 6226271,
        "type": 2,
        "start_time": 1746864600,
        "end_time": 1746864780,
        "title": "进房高光时刻",
        "cover": "",
        "extra": ""
      }
    ],
    "ass_url": "https://jssz-boss.hdslb.com/live2arc_anchor_video/dmass_1899237171_607113721045847859.ass?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=y4zI4XTQzlOkmSKg%2F20250520%2Fjssz%2Fs3%2Faws4_request&X-Amz-Date=20250520T130358Z&X-Amz-Expires=7200&X-Amz-SignedHeaders=host&X-Amz-Signature=5e3ddfbcb8893dc6e76deea7981165e18e5df9a7579f4e6e97c7a32abec53d84"
  }
}

获取某个时间的视频帧

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetAnchorVideoKeyFrame

请求方法: POST

认证方式: Cookie (SESSDATA)

鉴权方式: Cookie中bili_jct的值正确并与csrf相同

url参数:

参数名类型内容必要性备注
csrfstrCSRF Token(位于cookie)必要

正文参数( application/json ):

根对象:

参数名类型内容必要性备注
live_keystr标记直播场次的key必要
time_liststr秒时间戳列表,用,分隔必要时间间隔低于30秒将会导致只提供部分内容

json回复:

根对象:

字段类型内容备注
codenum返回值-400:请求错误
-111:csrf校验失败
-101:未登录
0:成功
messagestr错误信息成功时为"0"
ttlnum1
dataobj信息本体

data 对象:

字段类型内容备注
listarr指定时间的视频帧列表场次key无效时为null

data.list 数组中的对象:

字段类型内容备注
tsnum时间戳对应请求的time_list其中某一个
urlstr该时间的视频帧该时间有视频时存在

示例:

获取某场直播的视频帧

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/GetAnchorVideoKeyFrame?csrf=xxx' \
  -H 'Content-Type: application/json' \
  -b 'SESSDATA=xxx;bili_jct=xxx' \
  -d '{"live_key":"609431465787395891","time_list":"174758900,1747658930,1747658960"}'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data": {
    "list": [
      {
        "ts": 174758900
      },
      {
        "ts": 1747658930,
        "url": "https://jssz-boss.hdslb.com/live2arc_anchor_video/live_438160221_32373699_20250519204900.jpg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=y4zI4XTQzlOkmSKg%2F20250520%2Fjssz%2Fs3%2Faws4_request&X-Amz-Date=20250520T180202Z&X-Amz-Expires=7200&X-Amz-SignedHeaders=host&X-Amz-Signature=8d42a3d5fd1995e5e2bf98d453a986bec48529a9ae97d5d7eedee8a59b22418a"
      },
      {
        "ts": 1747658960,
        "url": "https://jssz-boss.hdslb.com/live2arc_anchor_video/live_438160221_32373699_20250519205001.jpg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=y4zI4XTQzlOkmSKg%2F20250520%2Fjssz%2Fs3%2Faws4_request&X-Amz-Date=20250520T180202Z&X-Amz-Expires=7200&X-Amz-SignedHeaders=host&X-Amz-Signature=f4a3803d4147492ced14eefbb6953e772b886e195d51dbfac800e77320adeba2"
      }
    ]
  }
}

投稿直播回放片段

https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorPublishVideoSlice

请求方法: POST

认证方式: Cookie (SESSDATA)

鉴权方式: Cookie中bili_jct的值正确并与csrf相同

正文参数( application/x-www-form-urlencoded ):

参数名类型内容必要性备注
live_keystr标记直播场次的key必要必须为自己的live_key
start_tsnum开始时间戳必要开始和结束时间目前相差不能大于2小时
end_tsnum结束时间戳必要开始和结束时间目前相差不能大于2小时
av_titlestr切片标题必要不能与现有标题重复
av_coverstr切片封面URL必要必须为.hdslb.com域名下的图片,否则合成结束时会出错
av_highlightnum高光绑定?非必要
with_subtitlenum是否自动生成字幕?非必要效果不明确
with_danmakunum是否带弹幕?非必要传递1时可能导致处于“发布中”状态时不在获取已发布片段的信息中显示
with_reservenum(?)非必要作用尚不明确
csrfstrCSRF Token(位于cookie)必要

json回复:

根对象:

字段类型内容备注
codenum返回值-111:csrf校验失败
-101:未登录
0:成功
4000:时长过长
4001:操作太快
4002:片段已投稿
4003:请选择精彩片段再投稿哦
4006:标题已使用
messagestr错误信息
ttlnum1
dataobj信息本体成功时有效

data 对象:

字段类型内容备注
video_slice_idnum切片id

注: 若返回值出现4001不一定就是操作太快,不提供某些必要参数或某个参数不正确也会导致返回4001。

示例:

为某个场次投稿切片

curl 'https://api.live.bilibili.com/xlive/app-blink/v1/anchorVideo/AnchorPublishVideoSlice' \
  --data-urlencode 'live_key=609431465787395891' \
  --data-urlencode 'start_ts=1747680306' \
  --data-urlencode 'end_ts=1747687506' \
  --data-urlencode 'av_title=2025051920' \
  --data-urlencode 'av_cover=https://i0.hdslb.com/bfs/live/59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png' \
  --data-urlencode 'av_highlight=0' \
  --data-urlencode 'with_subtitle=0' \
  --data-urlencode 'with_danmaku=0' \
  --data-urlencode 'csrf=xxx' \
  -b 'SESSDATA=xxx;bili_jct=xxx'
查看响应示例:
{
  "code": 0,
  "message": "0",
  "ttl": 1,
  "data":{
    "video_slice_id": 898374
  }
}

下载整场直播回放的流程

此处的流程是从直播回放open in new window的“下载回放”功能得出的。

  1. 请求整场直播回放下载链接接口,让它开始合成回放;

  2. (可选)请求获取回放的信息接口,生成合成进度页面;

  3. 轮询回放合成状态,当状态变为30转到流程4,变为-30转到流程5;

  4. 再次请求整场直播回放下载链接,获取下载链接并下载。

  5. 请求获取直播回放列表,刷新页面并根据信息提示失败。

直播回放片段发布页面

通过此处的链接可以打开直播回放片段发布页面。

https://live.bilibili.com/web-cut/quick-publish.html (网页端)

https://live.bilibili.com/web-cut/quick-publish-mobile.html (移动端)

注:移动端强制限制只能投稿15分钟的片段,网页端则看投稿直播回放片段接口允许多长的时间。

url查询参数:

参数名类型内容必要性备注
start_timenum直播开始时间必要对应获取直播回放列表data.replay_info[i].start_time
end_timenum直播结束时间必要对应获取直播回放列表data.replay_info[i].end_time
live_keystr标记直播场次的key必要对应获取直播回放列表data.replay_info[i].live_key
coverstr封面URL非必要可以自定义封面,或者在获取直播回放列表使用直播封面

示例链接:

网页端: https://live.bilibili.com/web-cut/quick-publish.html?start_time=1747508293&end_time=1747508499&live_key=609041817764368179&cover=https%3A%2F%2Fi0.hdslb.com%2Fbfs%2Flive%2F59fc254c1f51a962dbf69ae85e4920f2f6fb8dcd.png

移动端: https://live.bilibili.com/web-cut/quick-publish-mobile.html?start_time=1747508293&end_time=1747508499&live_key=609041817764368179

直播回放剪辑页面

此链接用于打开直播回放轻剪辑页面,在点击直播回放片段发布页面的“高级剪辑工具”或某一个回放剪辑草稿后自动打开。

https://live.bilibili.com/web-cut/index.html

url查询参数:

参数名类型内容必要性备注
start_timenum直播开始时间戳必要用于获取切片视频流
end_timenum直播结束时间戳必要用于获取切片视频流
live_keystr标记直播场次的key必要用于获取切片视频流
draft_idnum回放剪辑id必要

示例链接: https://live.bilibili.com/web-cut/index.html?start_time=1747658704&end_time=1747705213&live_key=609431465787395891&draft_id=988275