fix【README】typo, add doc【API签名】

This commit is contained in:
社会易姐QwQ 2022-01-30 22:37:57 +08:00
parent aae73c7015
commit 83cfcc80d6
4 changed files with 263 additions and 249 deletions

356
README.md
View File

@ -19,13 +19,13 @@
<h3 align="center">野生API文档</h3>
<h3 align="center">不断更新中....</h3>
本项目旨在对B站web端、移动端以及TV端散落在世界各地的野生api进行收集整理研究使用方法并对其进行说明运用了黑箱法、控制变量法、js逆向分析法、apk拆包及反编译法、网络抓包法等研究办法
本项目旨在对 B web 端、移动端以及 TV 端散落在世界各地的野生 api 进行收集整理研究使用方法并对其进行说明运用了黑箱法、控制变量法、js 逆向分析法、apk 拆包及反编译法、网络抓包法等研究办法
所有api均为标准http协议返回数据大都为json或protobuf
所有 rest api 均为标准 http 协议,请求数据大多为 url query 表单,返回数据大多为 json 或 protobuf
PS所有http协议地址均可使用https文档中为了统一写作`http`,为了数据安全建议所有接口使用https
PS所有 rest api 均可使用 https文档中为了统一写作`http`,为了数据安全建议调用接口时使用 https
小小的Demo~~av583785685~~[视频失效原因](https://shakaianee.top/archives/56/)[Youtube备链](https://www.youtube.com/watch?v=nfF91Z6fqGk)
小小的 Demo~~av583785685~~ [视频失效原因](https://shakaianee.top/archives/56/)[Youtube备链](https://www.youtube.com/watch?v=nfF91Z6fqGk)
联动项目:[Hsury/Bilibili-Toolkit](https://github.com/Hsury/Bilibili-Toolkit)
@ -33,7 +33,7 @@ PS所有http协议地址均可使用https文档中为了统一写作`http`
**声明**
1. 本项目遵守CC-BY-NC 4.0协议禁止一切商业使用如需转载请注明作者ID
1. 本项目遵守 CC-BY-NC 4.0 协议,禁止一切商业使用,如需转载请注明作者 ID
2. **请勿滥用,本项目仅用于学习和测试!请勿滥用,本项目仅用于学习和测试!请勿滥用,本项目仅用于学习和测试!**
3. 利用本项目提供的接口、文档等造成不良影响及后果与本人无关
4. 由于本项目的特殊性,可能随时停止开发或删档
@ -41,172 +41,172 @@ PS所有http协议地址均可使用https文档中为了统一写作`http`
---
计划整理分类&目录√代表已完成x代表正在施工...)二级目录正在建设中.....
计划整理分类 & 目录:(文档已完结请选中 checkbox)二级目录正在建设中.....
- [API认证与鉴权APP与Cookie方式](other/API_auth.md)×
- [公共错误码](other/errcode.md)
- [图片格式化](other/picture.md)
- [bvid说明](other/bvid_desc.md)
- [grpc接口](grpc_api)×
- [登录](login)
- [登录操作(人机认证)](login/login_action)
- [短信登录](login/login_action/SMS.md)
- [密码登录](login/login_action/password.md)
- [二维码登录](login/login_action/QR.md)
- SNS登录QQ&微博)
- [登录基本信息](login/login_info.md)
- [个人中心](login/member_center.md)×
- [注销登录](login/exit.md)×
- [登录记录](login/login_notice.md)
- [消息中心](message)
- [通知类消息](message/msg.md)×
- [私信](message/private_msg.md)×
- [设置](message/config.md)×
- [用户](user)
- [基本信息](user/info.md)
- [状态数](user/status_number.md)
- [关系](user/relation.md)
- [个人空间](user/space.md)x
- [检查昵称是否可注册](user/check_nickname.md)
- [用户注册](user/register.md)
- [大会员福利兑换](user/vip.md)
- [视频](video)
- [视频分区一览(分区代码)](video/video_zone.md)
- [基本信息](video/info.md)
- [状态数](video/status_number.md)
- [快照](video/snapshot.md)
- [点赞&投币&收藏](video/like_coin_fav.md)
- [TAG](video/tags.md)x
- [视频推荐](video/recommend.md)
- [播放&下载地址(视频流)](video/videostream_url.md)
- [互动视频](video/interact_video.md)×
- [高能进度条](video/pbp.md)
- [信息上报(心跳及记录历史)](video/report.md)×
- [视频属性数据](video/attribute_data.md)
- [视频在线人数](video/online.md)
- [剧集(番剧、影视)](bangumi)
- [基本信息](bangumi/info.md)×
- 状态数
- 操作
- [视频弹幕](danmaku)
- [protobuf实时弹幕](danmaku/danmaku_proto.md)
- [protobuf弹幕元数据BAS弹幕/互动弹幕)](danmaku/danmaku_view_proto.md)
- [xml实时弹幕](danmaku/danmaku_xml.md)
- [历史弹幕](danmaku/history.md)
- [快照](danmaku/snapshot.md)
- [弹幕操作](danmaku/action.md)×
- 高级弹幕
- 屏蔽管理
- 智能防挡弹幕
- [弹幕个人配置修改](danmaku/config.md)
- [名词解释](danmaku/buzzword.md)
- [视频笔记](note)
- [笔记列表](note/list.md)
- [笔记详细信息](note/info.md)
- [笔记操作](note/action.md)
- [专栏](article)
- 分区
- [基本信息](article/info.md)×
- [点赞&投币&收藏&分享](article/like_coin_fav.md)×
- [文集基本信息](article/articles.md)×
- [音频](audio)
- [歌曲基本信息](audio/info.md)
- [歌单&音频收藏夹详细信息](audio/music_list.md)×
- [状态数](audio/status_number.md)×
- [投币&收藏](audio/coin&fav.md)×
- [播放&下载地址(音频流)](audio/musicstream_url.md)
- 音频榜单
- [排行榜&最新视频](ranking&dynamic)
- [排行榜](ranking&dynamic/ranking.md)×
- [最新视频](ranking&dynamic/dynamic.md)×
- [搜索](search)
- [搜索请求](search/search_request.md)
- [搜索结果](search/search_response.md)
- [默认搜索&热搜](search/hot.md)
- [搜索建议](search/suggest.md)
- [小黑屋](blackroom)
- 基本信息
- [封禁公示](blackroom/banlist.md)
- [风纪委员及众裁案件相关](blackroom/jury)
- [风纪委员基本信息](blackroom/jury/base_info.md)
- [众裁案件基本信息](blackroom/jury/judgement_info.md)
- [裁决操作](blackroom/jury/action.md)
- [评论区](comment)
- [评论区明细](comment/list.md)
- [操作](comment/action.md)
- [表情](emoji)
- [表情及表情包信息](emoji/list.md)
- [操作](emoji/action.md)
- [创作中心](creativecenter)
- [统计与数据](creativecenter/statistics&data.md)×
- 列表查询相关
- [电磁力数据](creativecenter/railgun.md)
- [实时广播(通讯协议)](broadcast)
- [视频内广播](broadcast/video_room.md)
- [充电](electric)
- [B币方式](electric/Bcoin.md)
- [微信&支付宝方式](electric/WeChat&Alipay.md)
- [充电留言](electric/charge_msg.md)
- [充电列表](electric/charge_list.md)
- [动态](dynamic)
- [发送&转载动态](dynamic/publish.md)×
- [根据关键字搜索用户(at别人时的填充列表)](dynamic/atlist.md)
- [删除动态](dynamic/delete.md)
- 动态列表
- [特定话题动态列表](/dynamic/tag_dynamics.md)
- [动态内容](/dynamic/get_dynamic_detail.md)×
- 操作
- [相簿](album)
- [基本信息](album/info.md)
- [相簿列表](album/list.md)
- [推荐作者](album/recommend_author.md)
- [活动列表](album/activity_list.md)
- [操作](album/action.md)
- 投稿
- [历史记录&稍后再看](history&toview)
- [历史记录](history&toview/history.md)
- [稍后再看](history&toview/toview.md)
- [收藏夹](fav)
- [基本信息](fav/info.md)
- [收藏夹内容](fav/list.md)
- [收藏夹操作](fav/action.md)×
- [课程](cheese)
- [课程基本信息](cheese/info.md)
- 已购课程
- 分区推荐列表
- 操作
- [播放&下载地址(视频流)](cheese/videostream_url.md)
- [直播](live)
- [直播间基本信息](live/info.md)×
- [直播分区](live/live_area.md)×
- [直播间管理](live/manage.md)×
- 直播间操作
- [直播视频流](live/live_stream.md)×
- [直播信息流](live/message_stream.md)×
- [转正答题](newbie_exam)×
- [查询信息](newbie_exam/info.md)
- [拉取题目](newbie_exam/fetch.md)
- [操作](newbie_exam/action.md)
- B币钱包
- 基本信息
- B币充值
- 贝壳相关
- 哔哩哔哩漫画
- 哔哩哔哩游戏
- 轻视频
- [终端网络查询](clientinfo)
- [基于ip的地理位置查询](clientinfo/ip.md)
- [终端信息查询](clientinfo/client_info.md)
- [其他](other)
- [获取当前时间戳](other/time_stamp.md)
- [web端组件](web_widget)
- [分区当日投稿数](web_widget/zone_upload.md)
- [404页漫画收集](web_widget/404_manga.md)
- [APP端组件](APP_widget)
- [开屏图片](APP_widget/splash.md)
- [个性装扮](garb)
- [APP主题](garb/skin.md)
- [主题色](garb/color.md)
- [x] [API 签名](other/API_sign.md)
- [ ] [公共错误码](other/errcode.md)
- [x] [图片格式化](other/picture.md)
- [x] [bvid 说明](other/bvid_desc.md)
- [ ] [gRPC API 接口定义](grpc_api)
- [ ] [登录](login)
- [x] [登录操作(人机认证)](login/login_action)
- [x] [短信登录](login/login_action/SMS.md)
- [x] [密码登录](login/login_action/password.md)
- [x] [二维码登录](login/login_action/QR.md)
- [ ] SNS 登录QQ & 微博)
- [x] [登录基本信息](login/login_info.md)
- [ ] [个人中心](login/member_center.md)
- [ ] [注销登录](login/exit.md)
- [x] [登录记录](login/login_notice.md)
- [ ] [消息中心](message)
- [ ] [通知类消息](message/msg.md)
- [ ] [私信](message/private_msg.md)
- [ ] [设置](message/config.md)
- [ ] [用户](user)
- [x] [基本信息](user/info.md)
- [x] [状态数](user/status_number.md)
- [x] [关系](user/relation.md)
- [ ] [个人空间](user/space.md)
- [x] [检查昵称是否可注册](user/check_nickname.md)
- [x] [用户注册](user/register.md)
- [x] [大会员福利兑换](user/vip.md)
- [ ] [视频](video)
- [x] [视频分区一览(分区代码)](video/video_zone.md)
- [x] [基本信息](video/info.md)
- [x] [状态数](video/status_number.md)
- [x] [快照](video/snapshot.md)
- [x] [点赞 & 投币 & 收藏](video/like_coin_fav.md)
- [ ] [TAG](video/tags.md)
- [x] [视频推荐](video/recommend.md)
- [x] [播放&下载地址(视频流)](video/videostream_url.md)
- [ ] [互动视频](video/interact_video.md)
- [x] [高能进度条](video/pbp.md)
- [ ] [信息上报(心跳及记录历史)](video/report.md)
- [x] [视频属性数据](video/attribute_data.md)
- [x] [视频在线人数](video/online.md)
- [ ] [剧集(番剧、影视)](bangumi)
- [ ] [基本信息](bangumi/info.md)
- [ ] 状态数
- [ ] 操作
- [ ] [视频弹幕](danmaku)
- [x] [protobuf 实时弹幕](danmaku/danmaku_proto.md)
- [x] [protobuf 弹幕元数据BAS 弹幕 / 互动弹幕)](danmaku/danmaku_view_proto.md)
- [x] [xml 实时弹幕](danmaku/danmaku_xml.md)
- [x] [历史弹幕](danmaku/history.md)
- [x] [快照](danmaku/snapshot.md)
- [ ] [弹幕操作](danmaku/action.md)
- [ ] 高级弹幕
- [ ] 屏蔽管理
- [ ] 智能防挡弹幕
- [x] [弹幕个人配置修改](danmaku/config.md)
- [x] [名词解释](danmaku/buzzword.md)
- [x] [视频笔记](note)
- [x] [笔记列表](note/list.md)
- [x] [笔记详细信息](note/info.md)
- [x] [笔记操作](note/action.md)
- [ ] [专栏](article)
- [ ] 分区
- [ ] [基本信息](article/info.md)
- [ ] [点赞 & 投币 & 收藏 & 分享](article/like_coin_fav.md)
- [ ] [文集基本信息](article/articles.md)
- [ ] [音频](audio)
- [x] [歌曲基本信息](audio/info.md)
- [ ] [歌单 & 音频收藏夹详细信息](audio/music_list.md)
- [ ] [状态数](audio/status_number.md)
- [ ] [投币 & 收藏](audio/coin&fav.md)
- [x] [播放 & 下载地址(音频流)](audio/musicstream_url.md)
- [ ] 音频榜单
- [ ] [排行榜 & 最新视频](ranking&dynamic)
- [ ] [排行榜](ranking&dynamic/ranking.md)
- [ ] [最新视频](ranking&dynamic/dynamic.md)
- [ ] [搜索](search)
- [x] [搜索请求](search/search_request.md)
- [x] [搜索结果](search/search_response.md)
- [x] [默认搜索 & 热搜](search/hot.md)
- [x] [搜索建议](search/suggest.md)
- [ ] [小黑屋](blackroom)
- [ ] 基本信息
- [x] [封禁公示](blackroom/banlist.md)
- [x] [风纪委员及众裁案件相关](blackroom/jury)
- [x] [风纪委员基本信息](blackroom/jury/base_info.md)
- [x] [众裁案件基本信息](blackroom/jury/judgement_info.md)
- [x] [裁决操作](blackroom/jury/action.md)
- [x] [评论区](comment)
- [x] [评论区明细](comment/list.md)
- [x] [操作](comment/action.md)
- [ ] [表情](emoji)
- [x] [表情及表情包信息](emoji/list.md)
- [x] [操作](emoji/action.md)
- [ ] [创作中心](creativecenter)
- [ ] [统计与数据](creativecenter/statistics&data.md)
- [ ] 列表查询相关
- [x] [电磁力数据](creativecenter/railgun.md)
- [x] [实时广播(通讯协议)](broadcast)
- [x] [视频内广播](broadcast/video_room.md)
- [ ] [充电](electric)
- [x] [B币方式](electric/Bcoin.md)
- [x] [微信 & 支付宝方式](electric/WeChat&Alipay.md)
- [x] [充电留言](electric/charge_msg.md)
- [x] [充电列表](electric/charge_list.md)
- [ ] [动态](dynamic)
- [ ] [发送 & 转载动态](dynamic/publish.md)
- [ ] [根据关键字搜索用户at 别人时的填充列表)](dynamic/atlist.md)
- [ ] [删除动态](dynamic/delete.md)
- [ ] 动态列表
- [x] [特定话题动态列表](/dynamic/tag_dynamics.md)
- [ ] [动态内容](/dynamic/get_dynamic_detail.md)
- [ ] 操作
- [ ] [相簿](album)
- [x] [基本信息](album/info.md)
- [x] [相簿列表](album/list.md)
- [x] [推荐作者](album/recommend_author.md)
- [x] [活动列表](album/activity_list.md)
- [x] [操作](album/action.md)
- [ ] 投稿
- [ ] [历史记录 & 稍后再看](history&toview)
- [x] [历史记录](history&toview/history.md)
- [x] [稍后再看](history&toview/toview.md)
- [ ] [收藏夹](fav)
- [x] [基本信息](fav/info.md)
- [x] [收藏夹内容](fav/list.md)
- [ ] [收藏夹操作](fav/action.md)
- [ ] [课程](cheese)
- [x] [课程基本信息](cheese/info.md)
- [ ] 已购课程
- [ ] 分区推荐列表
- [ ] 操作
- [x] [播放 & 下载地址(视频流)](cheese/videostream_url.md)
- [ ] [直播](live)
- [ ] [直播间基本信息](live/info.md)
- [ ] [直播分区](live/live_area.md)
- [ ] [直播间管理](live/manage.md)
- [ ] 直播间操作
- [ ] [直播视频流](live/live_stream.md)
- [ ] [直播信息流](live/message_stream.md)
- [ ] [转正答题](newbie_exam)
- [x] [查询信息](newbie_exam/info.md)
- [x] [拉取题目](newbie_exam/fetch.md)
- [x] [操作](newbie_exam/action.md)
- [ ] B币钱包
- [ ] 基本信息
- [ ] B币充值
- [ ] 贝壳相关
- [ ] 哔哩哔哩漫画
- [ ] 哔哩哔哩游戏
- [ ] 轻视频
- [ ] [终端网络查询](clientinfo)
- [x] [基于ip的地理位置查询](clientinfo/ip.md)
- [x] [终端信息查询](clientinfo/client_info.md)
- [ ] [其他](other)
- [x] [获取当前时间戳](other/time_stamp.md)
- [ ] [web端组件](web_widget)
- [x] [分区当日投稿数](web_widget/zone_upload.md)
- [x] [404 页漫画收集](web_widget/404_manga.md)
- [ ] [APP端组件](APP_widget)
- [x] [开屏图片](APP_widget/splash.md)
- [ ] [个性装扮](garb)
- [x] [APP 主题](garb/skin.md)
- [x] [主题色](garb/color.md)
B站专栏同步推出[《B站api研究记》](https://www.bilibili.com/read/readlist/rl207146)系列(更新状态:咕咕......~~欢迎关注~~
@ -214,29 +214,29 @@ B站专栏同步推出[《B站api研究记》](https://www.bilibili.com/read/rea
# 相关协议基础
http协议[传送门](https://www.cnblogs.com/an-wen/p/11180076.html)
http 协议:[传送门](https://www.cnblogs.com/an-wen/p/11180076.html)
json序列格式[传送门](https://www.sojson.com/json/json_index.html)
json 序列格式:[传送门](https://www.sojson.com/json/json_index.html)
xml序列格式[传送门](https://www.w3school.com.cn/xml/xml_intro.asp)
xml 序列格式:[传送门](https://www.w3school.com.cn/xml/xml_intro.asp)
protobuf序列格式[传送门](https://www.jianshu.com/p/a24c88c0526a )
protobuf 序列格式:[传送门](https://www.jianshu.com/p/a24c88c0526a )
# 交流
<img src="imgs/up_face.jpg" width="100" height="100">
QQ粉丝交流群[1136462265](https://jq.qq.com/?_wv=1027&k=s1M0LCcu)
QQ 粉丝交流群:[1136462265](https://jq.qq.com/?_wv=1027&k=s1M0LCcu)
Telegram讨论组[bilibili_API_collect_community](https://t.me/bilibili_API_collect_community)
Telegram 讨论组:[@bilibili_API_collect_community](https://t.me/bilibili_API_collect_community)
B站空间<https://space.bilibili.com/293793435>
B 站空间:<https://space.bilibili.com/293793435>
个人博客:<https://shakaianee.top>
# 发电
欢迎来py,大家的支持就是我继续开发的动力!
欢迎来~~交♂易~~,大家的支持就是我继续开发的动力!
~~请可爱的易姐喝杯奶茶~~

View File

@ -337,8 +337,8 @@ curl -G 'http://api.bilibili.com/x/v2/dm/buzzword/list' \
| 字段 | 类型 | 内容 | 备注 |
| -------- | ---- | ------------ | -------- |
| aid | num | 视频 avid | |
| cid | num | 视频 1P cid | |
| aid | num | 稿件 avid | |
| cid | num | 视频 cid | |
| name | str | 视频标题 | |
| link | str | 空 | |
| play | num | 播放数 | |

View File

@ -1,69 +0,0 @@
# API认证与鉴权
- [Cookie方式web端](#Cookie方式web端)
- [APP方式手机客户端及TV端等](#APP方式手机客户端及TV端等)
---
## Cookie方式web端
cookie中的值在访问登录接口成功登录时用`set-cookie`写入
在访问api时为`Cookie`头的数据
Token有效期为1月更改密码或过期失效
| cookie项 | 含义 | 备注 |
| ----------------- | ----------------- | ------------------------------------------ |
| DedeUserID | 当前用户mid | |
| DedeUserID__ckMd5 | 用户mid md5校验值 | |
| SESSDATA | 登录Token | 用于用户识别与鉴权<br />作用同`access_key` |
| bili_jct | CSRF Token | 用于操作性接口 |
## APP方式手机客户端及TV端等
| 参数 | 含义 | 备注 |
| ------------- | ---------------- | ---------------------- |
| access_key | APP登录Token | 注意必须在第一个参数 |
| appkey | APP密钥 | |
| refresh_token | APP刷新登录Token | 仅在刷新时使用 |
| ts | 当前时间戳 | |
| sign | APP签名 | 注意必须在最后一个参数 |
**接口鉴权:**
使用`appkey`作为api的必要参数并使用除`sign`外所有参数的url字串后连接相对应的盐值进行**md5校验**32位小写把计算结果作为sign的值与前面参数一同发送
**appkey与appsec一一对应**
已知的appkey与签名
| appkey | appsecsign盐值 | 平台 | 应用 | 备注 |
| ---------------- | -------------------------------- | ---- | -------- | -------- |
| 07da50c9a0bf829f | 25bdede4e1581c836cab73a48790ca6e | 安卓 | 概念版 | |
| 1d8b6e7d45233436 | 560c52ccd288fed045859ed18bffd973 | 安卓 | 客户端 | 一般用途 |
| 178cf125136ca8ea | 34381a26236dd1171185c0beb042e1c6 | 安卓 | 概念版 | |
| 37207f2beaebf8d7 | e988e794d4d4b6dd43bc0e89d6e90c43 | 安卓 | biliLink | |
| 4409e2ce8ffd12b8 | 59b43e04ad6965f34319062b478f83dd | TV | 客户端 | |
| 57263273bc6b67f6 | a0488e488d1567960d3a765e8d129f90 | 安卓 | 客户端 | |
| 5dce947fe22167f9 | | 安卓 | 必剪 | |
| 7d336ec01856996b | a1ce6983bc89e20a36c37f40c4f1a0dd | 安卓 | 概念版 | |
| 85eb6835b0a1034e | 2ad42749773c441109bdc0191257a664 | | | |
| 8e16697a1b4f8121 | f5dd03b752426f2e623d7badb28d190a | 安卓 | 国际版 | |
| aae92bc66f3edfab | af125a0d5279fd576c1b4418a3e8276d | PC | 投稿工具 | |
| ae57252b0c09105d | c75875c596a69eb55bd119e74b07cfe3 | 安卓 | 国际版 | |
| bb3101000e232e27 | 36efcfed79309338ced0380abd824ac1 | 安卓 | 国际版 | |
| bca7e84c2d947ac6 | 60698ba2f68e01ce44738920a0ffe768 | 安卓 | 客户端 | 登录专用 |
| cc578d267072c94d | | 安卓 | 轻视频 | |
| cc8617fd6961e070 | | 安卓 | 漫画 | |
| iVGUTjsxvpLeuDCf | aHRmhWMLkdeMuILqORnYZocwMBpMEOdt | 安卓 | 客户端 | 取流专用 |
例如:
参数的url为`appkey=1d8b6e7d45233436&test=123`->连接盐值后为`appkey=1d8b6e7d45233436&test=123560c52ccd288fed045859ed18bffd973`->进行md5 32bit校验结果为`8a3fdd74911862810f5c78f65afcce5d`->最终参数为`appkey=1d8b6e7d45233436&test=123&sign=8a3fdd74911862810f5c78f65afcce5d`
**身份认证:**
使用参数` access_key `进行身份验证有效期为1月作用同`SESSDATA`
可以使用` refresh_token `进行刷新

83
other/API_sign.md Normal file
View File

@ -0,0 +1,83 @@
# API 签名与鉴权
部分客户端专用的 rest api 存在基于 sign 的鉴权,需要使用规定的`appkey`及其对应的`appsec`与原始请求参数进行签名计算
不同`appkey`对应不同的 app (如客户端、概念版、必剪、漫画、bililink等)
不同平台同 app 也会存在不同的 `appkey`(如安卓端、ios端、TV端等)
同平台同 app 下不同功能也会存在不同的 `appkey`(如登录专用、取流专用等)
**appkey与appsec一一对应**
- [API 签名的计算方式](#API 签名的计算方式)
- [已知的 APPKey](#已知的 APPKey)
---
## API 签名的计算方式
首先为参数中添加`appkey`字段,然后按照参数的 key 重新排序,再将重排序后的参数使用 url query 格式序列化拼接与该 appkey 相对应的 appsec (盐值) 进行**md5 hash计算**32位小写该 hash 便是 API 签名
为参数尾部增添`sign`字段,它的值为上一步计算所得的 hash一并作为表单提交
**实例:**
使用 appkey = `1d8b6e7d45233436`, appsec = `560c52ccd288fed045859ed18bffd973` 对如下 `params` 参数进行签名
```python
import hashlib
import urllib.parse
def appsign(params, appkey, appsec):
'为请求参数进行 api 签名'
params.update({'appkey': appkey})
params = dict(sorted(params.items())) # 重排序参数 key
query = urllib.parse.urlencode(params) # 序列化参数
sign = hashlib.md5((query+appsec).encode()).hexdigest() # 计算 api 签名
params.update({'sign':sign})
return params
appkey = '1d8b6e7d45233436'
appsec = '560c52ccd288fed045859ed18bffd973'
params = {
'id':114514,
'str':'1919810',
'test':'いいよ,こいよ',
}
signed_params = appsign(params, appkey, appsec)
query = urllib.parse.urlencode(signed_params)
print(signed_params)
print(query)
```
输出以下内容,分别是进行 api 签名后参数的 dict 以及 url query 格式
```
{'appkey': '1d8b6e7d45233436', 'id': 114514, 'str': '1919810', 'test': 'いいよ,こいよ', 'sign': '01479cf20504d865519ac50f33ba3a7d'}
appkey=1d8b6e7d45233436&id=114514&str=1919810&test=%E3%81%84%E3%81%84%E3%82%88%EF%BC%8C%E3%81%93%E3%81%84%E3%82%88&sign=01479cf20504d865519ac50f33ba3a7d
```
## 已知的 APPKey
| appkey | appsecsign盐值 | 平台 | 应用 | 备注 |
| ---------------- | -------------------------------- | ---- | -------- | -------- |
| 07da50c9a0bf829f | 25bdede4e1581c836cab73a48790ca6e | 安卓 | 概念版 | |
| 1d8b6e7d45233436 | 560c52ccd288fed045859ed18bffd973 | 安卓 | 客户端 | 一般用途 |
| 178cf125136ca8ea | 34381a26236dd1171185c0beb042e1c6 | 安卓 | 概念版 | |
| 27eb53fc9058f8c3 | c2ed53a74eeefe3cf99fbd01d8c9c375 | ios | 客户端 | 一般用途 |
| 37207f2beaebf8d7 | e988e794d4d4b6dd43bc0e89d6e90c43 | 安卓 | biliLink | |
| 4409e2ce8ffd12b8 | 59b43e04ad6965f34319062b478f83dd | TV | 客户端 | |
| 57263273bc6b67f6 | a0488e488d1567960d3a765e8d129f90 | 安卓 | 客户端 | |
| 5dce947fe22167f9 | | 安卓 | 必剪 | |
| 7d336ec01856996b | a1ce6983bc89e20a36c37f40c4f1a0dd | 安卓 | 概念版 | |
| 85eb6835b0a1034e | 2ad42749773c441109bdc0191257a664 | | | |
| 8e16697a1b4f8121 | f5dd03b752426f2e623d7badb28d190a | 安卓 | 国际版 | |
| aae92bc66f3edfab | af125a0d5279fd576c1b4418a3e8276d | PC | 投稿工具 | |
| ae57252b0c09105d | c75875c596a69eb55bd119e74b07cfe3 | 安卓 | 国际版 | |
| bb3101000e232e27 | 36efcfed79309338ced0380abd824ac1 | 安卓 | 国际版 | |
| bca7e84c2d947ac6 | 60698ba2f68e01ce44738920a0ffe768 | 安卓 | 客户端 | 登录专用 |
| cc578d267072c94d | | 安卓 | 轻视频 | |
| cc8617fd6961e070 | | 安卓 | 漫画 | |
| iVGUTjsxvpLeuDCf | aHRmhWMLkdeMuILqORnYZocwMBpMEOdt | 安卓 | 客户端 | 取流专用 |
| YvirImLGlLANCLvM | JNlZNgfNGKZEpaDTkCdPQVXntXhuiJEM | ios | 客户端 | 取流专用 |