diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index c316029..6c283a6 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -6,23 +6,29 @@ [bilibili-API-collect](https://github.com/SocialSisterYi/bilibili-API-collect) 项目(简称 BAC 或 b-a-c)是一个仅用于学习研究、社区开源、公益性质的 [B 站(哔哩哔哩)](https://www.bilibili.com/)API(应用程序接口)文档,使用 [CC-BY-NC 4.0 协议](https://github.com/SocialSisterYi/bilibili-API-collect/blob/master/LICENSE)开源,它将无差别收集整理相关的**主站业务接口**。 -该项目使用 [MarkDown](https://zh.wikipedia.org/zh-cn/Markdown) 语法进行文档书写,按照业务类型及功能以**路径**+**文件**形式索引,任何用户都可通过 Pull Request 提供自己分析出的接口地址与使用说明。 +该项目使用 [MarkDown](https://zh.wikipedia.org/zh-cn/Markdown) 语法进行文档书写,按照业务类型及功能以**路径**+**文件**形式索引,任何用户都可通过 Issue、Pull Request 与 Discussion 提供自己分析出的接口地址与使用说明。 本项目收集的接口类型包括但不限于 REST API、gRPC、WebSocket,文档内统一优先使用安全套接字协议,如 `https`、`securityRpc`、`wss`。 -## Issue 与社群讨论 +## Issue、Discussion 与社群讨论 -对文档内容存在**不理解**之处、以及发现文档内容有所**缺失**或**错误**,可直接提出,强烈建议以发 **Issue** 的形式参与用户反馈,并希望关于本项目的各种交流都是**公开进行**的,因为这样才可以保证关键信息的一致性。 +对文档内容存在**不理解**之处、以及发现文档内容有所**缺失**或**错误**,可直接提出,强烈建议以提交 **Issue** 的形式添加 / 补充 / 更新文档中的说明,以发起 **Discussion** 的形式提出问题、代码用例、情报分享,并希望关于本项目的各种交流都是**公开进行**的,因为这样才可以保证关键信息的一致性。 -由于本项目属于文档型项目,故不设置 Issue 模板,同时允许中英文标题,但提交 Issue 请遵守以下原则: +提交 Issue 请遵守以下原则: -1. 标题言简意骇,说明欲提出的问题要点,如 `如何通过 xx 接口获取 yy `、`xx 接口地址已失效`、`关于 xx 字段意义的探讨`、`建议将 xx 加入 yy 分类` 等标题;切勿使用表意含糊不清或索取性的标题,如 `怎么解决风控`、`补充`、`搜索的接口是什么`、`好兄弟有没有投稿的接口` 等标题 -2. Issue 正文应对问题进行尽可能详细的描述,展开并聚焦有关的信息,例如:“在前端页面某地址 / APP 某界面会访问某 API(标明地址),它的某参数与文档中不符(标明文档地址)” +1. 标题需要点明 API 的用处,如 `[新增请求] 新增 xx 接口`、`[更新请求] xx 接口地址已失效`、`[更新请求] xx 接口的参数有变化`,切勿仅填写 `补充`、`修复` 等标题 +2. 正文请按照 Issue 模板进行填写,标明 API 来源(Web、Android、iOS、TV 等)、API 类型(REST、gRPC、WebSocket 等)、API 地址 +3. 详情描述需要提供该 API 的使用场景、请求及响应字段等,可附上原始抓包记录;在更新时还需指出原文档中与最新 API 行为不符之处,并附上已知的最新改动。例如:“在前端页面某地址 / APP 某界面访问某 API(标明地址),它的某参数与文档中不符(标明文档地址)” + +发起 Discussion 请遵守以下原则: + +1. 标题言简意骇,说明欲提出的问题要点,如 `如何通过 xx 接口获取 yy`、`关于 xx 字段意义的探讨`、`建议将 xx 加入 yy 分类` 等标题;切勿使用表意含糊不清或索取性的标题,如 `怎么解决风控`、`搜索的接口是什么`、`好兄弟有没有投稿的接口` 等标题 +2. Discussion 正文应对遇到的问题进行尽可能详细的描述,展开并聚焦有关的信息,例如: “按照文档中某位置的说明进行了某操作,为什么无法获得预期结果”、“请问某 API 的某字段的具体含义是什么” 3. 提出问题时注意[提问的智慧](https://github.com/ryanhanwu/How-To-Ask-Questions-The-Smart-Way/blob/main/README-zh_CN.md)并且[别像弱智一样提问](https://github.com/tangx/Stop-Ask-Questions-The-Stupid-Ways) 同时,您还可以通过加入社群的方式参与讨论 -- QQ 交流群:[邀请链接](https://jq.qq.com/?_wv=1027&k=s1M0LCcu) +- QQ 交流群:[邀请链接](https://qm.qq.com/cgi-bin/qm/qr?_wv=1027&k=ympvb3LAPT-Ulu3ezhGqbkJ8zXMKImOX&authKey=z1KdkOdKO3wytN43m9K6On9nBtnDL4pAoD6VQHCipFBb9TasNDKuDHCmOE6TF3uc&noverify=0&group_code=191187164) - Telegram 交流群:[@bilibili_API_collect_community](https://t.me/bilibili_API_collect_community) ::: tip ✅提示 @@ -37,7 +43,7 @@ Telegram 交流群主要用作 [BAC 项目](https://github.com/SocialSisterYi/bi 群内讨论同样需要遵守**公开交流**的原则,以及群内会定期清理不活跃成员。 -**QQ 交流群**的加群问题答案可以去 [Owner 的主页](https://github.com/SocialSisterYi) Contact 部分找到,如果您填写“我不知道,从 Github 来的“那么管理员将有理由禁止您进群讨论! +**QQ 交流群**的加群问题答案可以去 [Owner 的主页](https://github.com/SocialSisterYi) Contact 部分找到,如果您填写“我不知道,从 Github 来的”那么管理员将有理由禁止您进群讨论! ::: @@ -51,24 +57,25 @@ Telegram 交流群主要用作 [BAC 项目](https://github.com/SocialSisterYi/bi ### 目录 -文档目录以 **Markdown 无序列表**语法写在 [README.md](README.md) 中,使用缩进标识文档的层级,如 `视频` 下存在 `基本信息`、`快照`、`推荐` 等子分类,使用 **Markdown 复选框**语法该标注文档是否编写完成 +文档目录以 **Markdown 无序列表**语法写在 [README.md](README.md) 中,使用缩进标识文档的层级,如 `视频` 下存在 `基本信息`、`快照`、`视频推荐`、`TAG` 等子分类,使用 **Markdown 复选框**语法该标注文档是否编写完成 ```markdown -- [x] 视频 +- [ ] 视频 - [x] 基本信息 - [x] 快照 - - [x] 推荐 + - [x] 视频推荐 + - [ ] TAG ``` ### 路径 -路径层级应当与文档目录一致,以文件夹的形式存放在项目中的 `/docs` 路径下,命名统一使用英文,如 `video`、`danmaku`、`comment` +路径层级应当与文档目录一致,以文件夹的形式存放在项目中的 `/docs` 路径下,命名统一使用英文小写,如 `video`、`danmaku`、`comment` -二级、三级路径应当存在二级三级目录,以 `README.md` 的形式 +二级、三级路径应当存在二级三级目录,可选添加 `README.md` 以描述该子目录 ### 文件 -各个子接口集整理为 md 文件,命名统一使用英文,如 `info.md`、`action.md`、`list.md` +各个子接口集整理为 MarkDown(md)文件,命名统一使用英文小写,如 `info.md`、`action.md`、`list.md` 文档文件中用于存放相关的接口的说明,如 `video/` 下的 `info.md`,存在 `查询视频基本信息`、`查询视频简介`、`查询视频分P列表` 等内容 @@ -80,9 +87,9 @@ Telegram 交流群主要用作 [BAC 项目](https://github.com/SocialSisterYi/bi ### 头部 -文档首行为**一级标签**格式标题 +文档首行为**一级标签**格式标题,如 `# 用户基本信息` -**文档头部不再需要手写索引** +**文档头部不再需要手写索引**,索引由 Vuepress 自动生成 ### 接口说明 @@ -98,7 +105,7 @@ Telegram 交流群主要用作 [BAC 项目](https://github.com/SocialSisterYi/bi 其他使用说明也可写在这里,如 `限制游客访问的视频需要登录` -eg: +e.g.: ```markdown ## 获取视频详细信息_web端 @@ -114,41 +121,42 @@ eg: **请求参数**应在**接口说明**的下方,应注明参数类型 url 参数或正文参数(正文参数应注明 content-type,如 `application/x-www-form-urlencoded` 或 `multipart/form-data`),使用**加粗**语法 -对象的字段及其含义使用**表格**进行整理,表头统一为 `参数名`、`类型`、`内容`、`必要性`、`备注`,类型为 `num`、`str`、`bool`、`nums`、`strs`、`file` 等,必要性为 `必要`、`非必要`、`必要 (可选)` 等,表格内每个字段为一行 +对象的字段及其含义使用**表格**进行整理,表头统一依次为 `参数名`、`类型`、`内容`、`必要性`、`备注`,类型为 `num`、`str`、`bool`、`nums`、`strs`、`file` 等,必要性为 `必要`、`非必要`、`必要 (可选)` 等,表格内每个字段为一行 -eg: +e.g.: | 参数名 | 类型 | 内容 | 必要性 | 备注 | | ------ | ---- | --------- | ----------- | ----------------- | | aid | num | 稿件 avid | 必要 (可选) | avid 与 bvid 任选 | | bvid | str | 稿件 bvid | 必要 (可选) | avid 与 bvid 任选 | -**响应正文**应在**请求参数**的下方,接口响应的数据格式应标注,如 `JSON 回复`、`XML 回复`、`Protobuf 回复`,使用**加粗**语法 +**响应正文**应在**请求参数**的下方,接口响应的数据格式应标注,如 `JSON 回复`、`XML 回复`、`ProtoBuf 回复`,使用**加粗**语法 -json object 或 protobuf message 应以对象的**表格**形式书写,表头为 `根对象` 或 `xx 中的 yy 对象`,若对象位于数组中为 `xx 数组中的对象` +JSON Object 或 ProtoBuf Message 应以对象的**表格**形式书写,表头为 `根对象` 或 `xx 中的 yy 对象`,若对象位于数组中则为 `xx 数组中的对象` -表头统一为 `字段`、`类型`、`内容`、`备注`,类型为 JSON / Protobuf 的标准类型 +表头统一依次为 `字段`、`类型`、`内容`、`备注`,类型为 JSON / Protobuf 的标准类型,如 `num`、`str`、`bool`、`obj`、`array`、`null` 等 -不明确定义的字段说明在末尾添加问号,如 `播放数?`;定义尚未明确的字段使用问号包于括号中占位,如 `(?)` +不明确定义的字段说明在内容的末尾添加问号,如 `播放数?`;定义尚未明确的字段使用 `(?)` 在内容中占位,并在备注中填写 `作用尚不明确` 多个对象及数组,使用**遍历树**的顺序进行排列 -eg: +e.g.: `data` 对象: -| 字段 | 类型 | 内容 | 备注 | -| ------ | ---- | ----------- | -------- | -| bvid | str | 稿件 bvid | | -| aid | num | 稿件 avid | | -| videos | num | 稿件分P总数 | 默认为 1 | -| tid | num | 分区 tid | | +| 字段 | 类型 | 内容 | 备注 | +| -------- | ---- | ----------- | ------------ | +| bvid | str | 稿件 bvid | | +| aid | num | 稿件 avid | | +| videos | num | 稿件分P总数 | 默认为 1 | +| tid | num | 分区 tid | | +| no_cache | bool | (?) | 作用尚不明确 | -json array 或 protobuf repeated 类型使用数组的**表格**形式书写,表头统一为 `项`、`类型`、`内容`、`备注`,无限长度数组表尾需要添加**省略号** +Json Array 或 ProtoBuf Repeated 类型使用数组的**表格**形式书写,表头统一依次为 `项`、`类型`、`内容`、`备注`,无限长度数组表尾需要添加**省略号** 数组每项内容若与实际数据有关联,`内容` 字段则可标为 `(n+1)P 视频内容` 这样的形式 -eg: +e.g.: `data` 中的 `pages` 数组: @@ -166,9 +174,9 @@ eg: 示例命令前后可以适当添加一些文字说明 -响应体示例为一段格式化后的 JSON 或 protobuf message,使用**代码块**语法书写,并使用 `
` 标签进行折叠 +响应体示例为一段格式化后的 JSON 或 ProtoBuf Message,使用**代码块**语法书写,并使用 `
` 标签进行折叠 -eg: +e.g.: ````markdown **示例:** @@ -211,22 +219,22 @@ curl -G 'https://api.bilibili.com/x/web-interface/view' \ 这些枚举值或属性位的用法应附加文字说明 -eg: +e.g.: | 值 | 含义 | 备注 | | ---- | ------------- | ------------------------------------------------------------ | -| 6 | 240P 极速 | 仅 MP4 格式支持
仅 `platform=html5` 时有效 | +| 6 | 240P 极速 | 仅 MP4 格式支持
仅 `platform=html5` 时有效 | | 16 | 360P 流畅 | | | 32 | 480P 清晰 | | | 64 | 720P 高清 | WEB 端默认值
B 站前端需要登录才能选择,但是直接发送请求可以不登录就拿到 720P 的取流地址
**无 720P 时则为 720P60** | -| 74 | 720P60 高帧率 | 登录认证 | -| 80 | 1080P 高清 | TV 端与 APP 端默认值
登录认证 | +| 74 | 720P60 高帧率 | 需要登录认证 | +| 80 | 1080P 高清 | TV 端与 APP 端默认值
需要登录认证 | ## Proto 定义格式 proto 文件为 [Protocol Buffers](https://protobuf.dev/) 以及 [gRPC](https://grpc.io/docs/) 的数据结构体定义,多用于客户端的接口,本文档也做相关的收集 -存放于项目的 `/grpc_api` 路径下,使用包名进行路径层级的组织,如 +存放于项目的 `/grpc_api` 路径下,使用包名进行路径层级的组织,如: ``` /grpc_api/bilibili/main/community/reply/v1/reply.proto @@ -234,7 +242,7 @@ proto 文件为 [Protocol Buffers](https://protobuf.dev/) 以及 [gRPC](https:// /grpc_api/bilibili/app/view/v1/view.proto ``` -proto 文件内使用**单行注释**标注字段或对象的含义,如 +proto 文件内使用**单行注释**标注字段或对象的含义,如: ```protobuf // UP主信息 @@ -250,4 +258,6 @@ message Author { ## 文档提交 -TODO +使用 Pull Request 将修改后的文档提交到 `master` 分支,标题需写明提交的内容 + +(TODO) diff --git a/docs/message/private_msg.md b/docs/message/private_msg.md index bbc19cc..cee62c0 100644 --- a/docs/message/private_msg.md +++ b/docs/message/private_msg.md @@ -501,7 +501,7 @@ curl -G 'https://api.vc.bilibili.com/session_svr/v1/session_svr/new_sessions' \ | 字段 | 类型 | 内容 | 备注 | | ------- | ---- | -------- | ------------------------------------------------- | -| code | num | 返回值 | 0:成功
-101:账号未登录
-400:请求错误 | +| code | num | 返回值 | 0:成功
2:非法参数
-101:账号未登录
-400:请求错误 | | msg | str | 错误信息 | 默认为0 | | message | str | 错误信息 | 默认为0 | | ttl | num | 1 | | diff --git a/docs/user/relation.md b/docs/user/relation.md index fbe4eb2..4c4f1ac 100644 --- a/docs/user/relation.md +++ b/docs/user/relation.md @@ -1682,7 +1682,7 @@ curl -G 'https://api.bilibili.com/x/relation/relations' \ | 项 | 类型 | 内容 | 备注 | | ---- | ---- | ----------- | ---- | -| 1 | obj | 分组 1 | | +| 0 | obj | 分组 1 | | | n | obj | 分组(n+1) | | | …… | num | …… | …… |