From 3893a323d750de669bec7bc13a1d16867fa0b03f Mon Sep 17 00:00:00 2001
From: SocialSisterYi <1440239038@qq.com>
Date: Fri, 20 Jan 2023 23:58:07 +0800
Subject: [PATCH] add contributing guide
---
README.md | 36 +++++---
contributing_guide.md | 196 ++++++++++++++++++++++++++++++++++++++++++
2 files changed, 219 insertions(+), 13 deletions(-)
create mode 100644 contributing_guide.md
diff --git a/README.md b/README.md
index 427af41..f9472a5 100644
--- a/README.md
+++ b/README.md
@@ -29,9 +29,7 @@ B站 API 采用 C/S 结构,大多数接口为 REST API 和 gRPC,少部分接
联动项目:[Hsury/Bilibili-Toolkit](https://github.com/Hsury/Bilibili-Toolkit)
----
-
-**声明**:
+## **⚠️声明**
1. 本项目遵守 CC-BY-NC 4.0 协议,禁止一切商业使用,如需转载请注明作者 ID
2. **请勿滥用,本项目仅用于学习和测试!请勿滥用,本项目仅用于学习和测试!请勿滥用,本项目仅用于学习和测试!**
@@ -39,9 +37,21 @@ B站 API 采用 C/S 结构,大多数接口为 REST API 和 gRPC,少部分接
4. 由于本项目的特殊性,可能随时停止开发或删档
5. 本项目为开源项目,不接受任何形式的催单和索取行为,更不容许存在付费内容
----
+## 🌱参与贡献
-计划整理分类 & 目录:(文档已完结请选中 checkbox) 二级目录正在建设中.....
+欢迎各位 dalao 对本项目做出贡献,也希望每个使用者都能提出宝贵的意见
+
+目前本项目存在的问题包括但不限于:
+
+1. 文档二级目录尚未完成
+2. 文档需要使用 Vue Press 构建 html 版本发布
+3. 部分文档较旧,修改与更新没有跟进
+
+更多信息请浏览 [贡献指南](contributing_guide.md)
+
+## 🍴目录
+
+计划整理分类 & 目录:(文档已完结请选中 checkbox)
- [x] [API 签名](other/API_sign.md)
- [x] [公共错误码](other/errcode.md)
@@ -225,13 +235,13 @@ B站 API 采用 C/S 结构,大多数接口为 REST API 和 gRPC,少部分接
- [x] [APP 主题](garb/skin.md)
- [x] [主题色](garb/color.md)
-# 鸣谢
+## ✨鸣谢
你们的存在,让社区更美好
[](https://github.com/SocialSisterYi/bilibili-API-collect/graphs/contributors)
-# 相关协议基础
+## 📖相关协议基础
http 协议:[传送门](https://www.cnblogs.com/an-wen/p/11180076.html)
@@ -241,7 +251,7 @@ xml 序列格式:[传送门](https://www.w3school.com.cn/xml/xml_intro.asp)
protobuf 序列格式:[传送门](https://www.jianshu.com/p/a24c88c0526a )
-# 交流
+## 💦交流
@@ -255,7 +265,7 @@ B 站空间:
个人博客:
-# 发电
+## 🧋发电
欢迎来~~交♂易~~,大家的支持就是我继续开发的动力!
@@ -267,9 +277,9 @@ WeChat & Alipay:
OR Aifadian:https://afdian.net/@ShakaiAneE
-# 相关项目推荐
+## 🔗相关项目推荐
-## 库及文档
+### 库及文档
- [jingyuexing/bilibiliAPI](https://github.com/jingyuexing/bilibiliAPI)
- [fython/BilibiliAPIDocs](https://github.com/fython/BilibiliAPIDocs)
@@ -285,7 +295,7 @@ OR Aifadian:https://afdian.net/@ShakaiAneE
- [ddiu8081/blive-message-listener](https://github.com/ddiu8081/blive-message-listener): Bilibili-live danmu listener with type. Bilibili 直播间弹幕监听库,支持类型输出。
- [Nemo2011/bilibili-api](https://github.com/Nemo2011/bilibili-api): 哔哩哔哩常用API调用。支持视频、番剧、用户、频道、音频等功能。工具齐全。
-## 成品
+### 成品
- [NullPointerException/AnimePipe](https://codeberg.org/NullPointerException/AnimePipe): 功能完善的Android流媒体综合客户端,支持Bilibili, Youtube, NicoNico
- [3Shain/BiliChat](https://github.com/3Shain/BiliChat) : 基于h5的B站直播弹幕姬
@@ -312,7 +322,7 @@ OR Aifadian:https://afdian.net/@ShakaiAneE
- [SocialSisterYi/bcut-asr](https://github.com/SocialSisterYi/bcut-asr): 使用必剪API的语音字幕识别
- [CzJam/Bili_Realtime_Data](https://github.com/CzJam/Bili_Realtime_Data): Bilibili粉丝与视频实时数据统计
-## 其他
+### 其他
- [kuresaru/geetest-validator](https://github.com/kuresaru/geetest-validator):geetest调试器
diff --git a/contributing_guide.md b/contributing_guide.md
new file mode 100644
index 0000000..9598b2d
--- /dev/null
+++ b/contributing_guide.md
@@ -0,0 +1,196 @@
+# bilibili-API-collect
+
+欢迎来到 bilibili-API-collect 社区贡献指南,本文主要面向需要进行提交贡献文档内容的用户。
+
+## 总则
+
+[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 协议](LICENSE) 开源,它将无差别收集整理相关的**主站业务接口**。
+
+该项目使用 [MarkDown](https://zh.wikipedia.org/zh-cn/Markdown) 语法进行文档书写,按照业务类型及功能以 **路径** + **文件** 形式索引,任何用户都可通过 Pull Request 提供自己分析出的接口地址与使用说明。
+
+本项目收集的接口类型包括但不限于 REST API、gRPC、WebSocket,文档内统一优先使用安全套接字协议,如`https`、`securityRpc`、`wss`。
+
+## 目录与路径结构
+
+### 目录
+
+文档目录以 **列表** 语法写在 [README.md](README.md) 中,使用缩进标识文档的层级,如`视频`下存在`基本信息`、`快照`、`推荐`等子分类
+
+### 路径
+
+路径层级应当与文档目录一致,以文件夹的形式存放在项目中,命名统一使用英文,如`video`、`danmaku`、`comment`
+
+二级、三级路径应当存在二级三级目录,以`README.md`的形式
+
+### 文件
+
+各个子接口集整理为 md 文件,命名统一使用英文,如`info.md`、`action.md`、`list.md`
+
+文档文件中用于存放相关的接口的说明,如`video/`下的`info.md`,存在`查询视频基本信息`、`查询视频简介`、`查询视频分P列表`等内容
+
+## 文档内容格式
+
+注:以下文档范式可根据**实际情况**进行调整
+
+### 头部
+
+文档首行为 **一级标签** 格式标题
+
+标题下方为索引,与正文二级标题对应,使用 **列表** 语法与缩进,每项使用 **超链接** 语法实现 id 锚点跳转
+
+头部结束应使用 **分隔线** 语法划线分割
+
+```markdown
+# 视频
+
+- [获取视频详细信息](#获取视频详细信息)
+- [获取视频简介](#获取视频简介)
+
+---
+```
+
+### 接口说明
+
+文档中可存在多个接口说明,应当遵守同一范式,依次排列在文档中
+
+接口说明分为`标题`、`地址`、`说明`、`请求参数`、`响应正文`、`示例`这些部分
+
+接口标题为 **二级以下** 的标签,接口地址使用 **引用** 语法,地址只保留 REST API 路径,不应携带 query 等内容
+
+接口地址下方需要注明接口的请求方式,如`GET`、`POST`、`PUT`等,使用 **斜体** 语法
+
+若接口存在认证或鉴权,需要在说明中注明,如`Cookie(SESSDATA)`、`APP`(认证是针对用户的,鉴权是针对接口使用的
+
+其他使用说明也可写在这里,如`限制游客访问的视频需要登录`
+
+eg:
+
+```markdown
+## 获取视频详细信息_web端
+
+> https://api.bilibili.com/x/web-interface/view
+
+*请求方式:GET*
+
+认证方式:Cookie(SESSDATA)
+
+限制游客访问的视频需要登录
+```
+
+**请求参数**应在**接口说明**的下方,应注明参数类型 url 参数或 正文参数(正文参数应注明 content-type,如`application/x-www-form-urlencoded`或`multipart/form-data`),使用 **加粗** 语法
+
+对象的字段及其含义使用 **表格** 进行整理,表头统一为`参数名`、`类型`、`内容`、`必要性`、`备注`,类型为`num`、`str`、`bool`、`nums`、`strs`、`file`等,必要性为`必要`、`非必要`、`必要(可选)`等,表格内每个字段为一行
+
+eg:
+
+| 参数名 | 类型 | 内容 | 必要性 | 备注 |
+| ------ | ---- | --------- | ----------- | ----------------- |
+| aid | num | 稿件 avid | 必要 (可选) | avid 与 bvid 任选 |
+| bvid | str | 稿件 bvid | 必要 (可选) | avid 与 bvid 任选 |
+
+**响应正文**应在**请求参数**的下方,接口响应的数据格式应标注,如`JSON回复`、`XML回复`、`Protobuf回复`,使用 **加粗** 语法
+
+json object 或 protobuf message 应以对象的 **表格** 形式书写,表头为`根对象`或`xx中的yy对象`,若对象位于数组中为`xx数组中的对象`
+
+表头统一为`字段`、`类型`、`内容`、`备注`,类型为 JSON / Protobuf 的标准类型
+
+不明确定义的字段说明在末尾添加问号,如`播放数?`;定义尚未明确的字段使用问号包于括号中占位,如`(?)`
+
+多个对象及数组,使用**遍历树**的顺序进行排列
+
+eg:
+
+`data`对象:
+
+| 字段 | 类型 | 内容 | 备注 |
+| ------ | ---- | ----------- | -------- |
+| bvid | str | 稿件 bvid | |
+| aid | num | 稿件 avid | |
+| videos | num | 稿件分P总数 | 默认为 1 |
+| tid | num | 分区 tid | |
+
+json array 或 protobuf repeated 类型使用数组的 **表格** 形式书写,表头统一为`项`、`类型`、`内容`、`备注`,无限长度数组表尾需要添加**省略号**
+
+数组每项内容若与实际数据有关联,`内容`字段则可标为`(n+1)P 视频内容`这样的形式
+
+eg:
+
+`data`中的`pages`数组:
+
+| 项 | 类型 | 内容 | 备注 |
+| ---- | ---- | --------------- | ------------- |
+| 0 | obj | 1P 视频内容 | 无分P仅有此项 |
+| n | obj | (n+1)P 视频内容 | |
+| …… | obj | …… | …… |
+
+**示例**部分位于所有**响应正文**部分下方,需要**加粗**格式,分为请求命令示例与响应体示例两部分
+
+请求命令示例为一段可测试该接口的 curl 命令或 Python 脚本,使用 **代码块** 语法书写,命令应当尽可能简短、便于使人阅读
+
+示例命令中的认证信息应做**脱敏处理**,如 Cookie、Token、access_key 等,可替换为`xxx`占位
+
+示例命令前后可以适当添加一些文字说明
+
+响应体示例为一段格式化后的 JSON 或 protobuf message,使用 **代码块** 语法书写,并使用``标签进行折叠
+
+eg:
+
+**示例:**
+
+获取视频`av85440373`的基本信息
+
+```shell
+curl -G 'https://api.bilibili.com/x/web-interface/view' \
+ --data-urlencode 'aid=85440373'
+```
+
+```html
+
+查看响应示例:
+```
+
+```json
+{
+ "code": 0,
+ "message": "0",
+ "ttl": 1,
+ "data": {
+ "bvid": "BV117411r7R1",
+ "aid": 85440373,
+ "videos": 1,
+ "tid": 28,
+ "tname": "原创音乐",
+ "copyright": 1,
+ ...
+```
+
+```html
+
+```
+
+### 枚举值与属性位
+
+接口返回或请求中若存在一些 enum 类型或二进制属性位,应当单独进行探讨,如视频的属性位`attribute`或视频清晰度`qn`
+
+这些值及其说明使用 **表格** 进行整理,表头统一为`位` / `代码` / `值`、`含义`、`备注`
+
+这些枚举值或属性位的用法应附加文字说明
+
+eg:
+
+| 值 | 含义 | 备注 |
+| ---- | ------------- | ------------------------------------------------------------ |
+| 6 | 240P 极速 | 仅 MP4 格式支持
仅`platform=html5`时有效 |
+| 16 | 360P 流畅 | |
+| 32 | 480P 清晰 | |
+| 64 | 720P 高清 | WEB 端默认值
B站前端需要登录才能选择,但是直接发送请求可以不登录就拿到 720P 的取流地址
**无 720P 时则为 720P60** |
+| 74 | 720P60 高帧率 | 登录认证 |
+| 80 | 1080P 高清 | TV 端与 APP 端默认值
登录认证 |
+
+## 文档提交
+
+TODO
+
+## Issue与社群讨论
+
+TODO
\ No newline at end of file