2019-12-17 11:02:45 +08:00
|
|
|
|
# mirai-api-http
|
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
<b>Mirai-API-http 提供HTTP API供所有语言使用mirai</b>
|
|
|
|
|
|
2020-02-05 23:40:36 +08:00
|
|
|
|
## 快速开始
|
2020-02-05 00:12:21 +08:00
|
|
|
|
|
|
|
|
|
```kotlin
|
|
|
|
|
fun main() {
|
|
|
|
|
val bot = Bot(123456789, "password")
|
|
|
|
|
|
|
|
|
|
bot.login()
|
|
|
|
|
|
|
|
|
|
MiraiHttpAPIServer.start()
|
|
|
|
|
|
|
|
|
|
bot.network.awaitDisconnection()
|
|
|
|
|
}
|
|
|
|
|
```
|
2020-02-03 03:12:44 +08:00
|
|
|
|
|
2020-02-05 23:40:36 +08:00
|
|
|
|
## 认证相关
|
|
|
|
|
|
2019-12-17 11:45:08 +08:00
|
|
|
|
### 开始会话-认证(Authorize)
|
|
|
|
|
|
2020-02-03 03:12:44 +08:00
|
|
|
|
```
|
|
|
|
|
[POST] /auth
|
2019-12-17 11:45:08 +08:00
|
|
|
|
```
|
2020-02-05 00:12:21 +08:00
|
|
|
|
使用此方法验证你的身份,并返回一个会话
|
2019-12-17 11:45:08 +08:00
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"authKey": "U9HSaDXl39ksd918273hU"
|
|
|
|
|
}
|
|
|
|
|
```
|
2019-12-17 11:45:08 +08:00
|
|
|
|
|
2020-02-05 19:26:52 +08:00
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ------- | ------ | ----- | ----------------------- | ---------------------------------------------------------- |
|
|
|
|
|
| authKey | String | false | "U9HSaDXl39ksd918273hU" | 创建Mirai-Http-Server时生成的key,可在启动时指定或随机生成 |
|
2019-12-17 11:45:08 +08:00
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
#### 响应: 返回(成功):
|
2020-02-03 03:12:44 +08:00
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"session": "UnVerifiedSession"
|
|
|
|
|
}
|
|
|
|
|
```
|
2019-12-17 11:45:08 +08:00
|
|
|
|
|
2020-02-05 19:26:52 +08:00
|
|
|
|
| 名字 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ------- | ------ | ------------------- | --------------- |
|
|
|
|
|
| code | Int | 0 | 返回状态码 |
|
|
|
|
|
| session | String | "UnVerifiedSession" | 你的session key |
|
2019-12-17 11:45:08 +08:00
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
#### 状态码:
|
2019-12-17 11:45:08 +08:00
|
|
|
|
|
2020-02-05 19:26:52 +08:00
|
|
|
|
| 代码 | 原因 |
|
|
|
|
|
| ---- | ----------------------------- |
|
|
|
|
|
| 0 | 正常 |
|
|
|
|
|
| 1 | 错误的MIRAI API HTTP auth key |
|
2019-12-17 11:45:08 +08:00
|
|
|
|
|
2020-02-05 19:26:52 +08:00
|
|
|
|
session key 是使用以下方法必须携带的
|
2020-02-05 00:12:21 +08:00
|
|
|
|
session key 使用前必须进行校验和绑定指定的Bot,**每个Session只能绑定一个Bot,但一个Bot可有多个Session**
|
2020-02-05 19:26:52 +08:00
|
|
|
|
session Key 在未进行校验的情况下,一定时间后将会被自动释放
|
2020-02-03 03:12:44 +08:00
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
|
|
|
|
|
### 校验Session
|
|
|
|
|
|
|
|
|
|
```
|
2020-02-05 19:26:52 +08:00
|
|
|
|
[POST] /verify
|
2020-02-05 00:12:21 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
使用此方法校验并激活你的Session,同时将Session与一个**已登录**的Bot绑定
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "UnVerifiedSession",
|
|
|
|
|
"qq": 123456789
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ------ | ----- | ------------------- | -------------------------- |
|
|
|
|
|
| sessionKey | String | false | "UnVerifiedSession" | 你的session key |
|
|
|
|
|
| qq | Long | false | 123456789 | Session将要绑定的Bot的qq号 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码(后续不再赘述)
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2020-02-05 23:40:36 +08:00
|
|
|
|
| 状态码 | 原因 |
|
|
|
|
|
| ------ | ----------------------------------- |
|
|
|
|
|
| 0 | 正常 |
|
|
|
|
|
| 1 | 错误的auth key |
|
|
|
|
|
| 2 | 指定的Bot不存在 |
|
|
|
|
|
| 3 | Session失效或不存在 |
|
|
|
|
|
| 4 | Session未认证(未激活) |
|
|
|
|
|
| 5 | 发送消息目标不存在(指定对象不存在) |
|
|
|
|
|
| 10 | 无操作权限,指Bot没有对应操作的限权 |
|
|
|
|
|
| 400 | 错误的访问,如参数错误等 |
|
2020-02-05 00:12:21 +08:00
|
|
|
|
|
2020-02-05 19:26:52 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 释放Session
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /release
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
使用此方式释放session及其相关资源(Bot不会被释放)
|
|
|
|
|
**不使用的Session应当被释放,否则Session持续保存Bot收到的消息,将会导致内存泄露**
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSessionKey",
|
|
|
|
|
"qq": 123456789
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ------ | ----- | -----------------| -------------------------- |
|
|
|
|
|
| sessionKey | String | false | "YourSessionKey" | 你的session key |
|
|
|
|
|
| qq | Long | false | 123456789 | 与该Session绑定Bot的QQ号码 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
> SessionKey与Bot 对应错误时将会返回状态码5:指定对象不存在
|
|
|
|
|
|
|
|
|
|
|
2020-02-05 23:40:36 +08:00
|
|
|
|
## 消息相关
|
|
|
|
|
|
2020-02-03 03:12:44 +08:00
|
|
|
|
|
|
|
|
|
### 发送好友消息
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /sendFriendMessage
|
|
|
|
|
```
|
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
使用此方法向指定好友发送消息
|
|
|
|
|
|
|
|
|
|
#### 请求
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSession",
|
|
|
|
|
"target": 987654321,
|
|
|
|
|
"messageChain": [
|
|
|
|
|
{ "type": "Plain", "text":"hello\n" },
|
|
|
|
|
{ "type": "Plain", "text":"world" }
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ------------ | ------ | ----- | ----------- | -------------------------------- |
|
|
|
|
|
| sessionKey | String | false | YourSession | 已经激活的Session |
|
|
|
|
|
| target | Long | false | 987654321 | 发送消息目标好友的QQ号 |
|
|
|
|
|
| messageChain | Array | false | [] | 消息链,是一个消息对象构成的数组 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 发送群消息
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /sendGroupMessage
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
使用此方法向指定群发送消息
|
|
|
|
|
|
|
|
|
|
#### 请求
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSession",
|
|
|
|
|
"target": 987654321,
|
|
|
|
|
"messageChain": [
|
|
|
|
|
{ "type": "Plain", "text":"hello\n" },
|
|
|
|
|
{ "type": "Plain", "text":"world" }
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ------------ | ------ | ----- | ----------- | -------------------------------- |
|
|
|
|
|
| sessionKey | String | false | YourSession | 已经激活的Session |
|
|
|
|
|
| target | Long | false | 987654321 | 发送消息目标群的群号 |
|
|
|
|
|
| messageChain | Array | false | [] | 消息链,是一个消息对象构成的数组 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-02-14 23:35:58 +08:00
|
|
|
|
### 发送引用回复消息(仅支持群消息)
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /sendQuoteMessage
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
使用此方法向指定的消息进行引用回复
|
|
|
|
|
|
|
|
|
|
#### 请求
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSession",
|
|
|
|
|
"target": 987654321,
|
|
|
|
|
"messageChain": [
|
|
|
|
|
{ "type": "Plain", "text":"hello\n" },
|
|
|
|
|
{ "type": "Plain", "text":"world" }
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ------------ | ------ | ----- | ----------- | -------------------------------- |
|
|
|
|
|
| sessionKey | String | false | YourSession | 已经激活的Session |
|
|
|
|
|
| target | Long | false | 987654321 | 引用消息的Message Source的Uid |
|
|
|
|
|
| messageChain | Array | false | [] | 消息链,是一个消息对象构成的数组 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-02-09 18:06:47 +08:00
|
|
|
|
### 发送图片消息(通过URL)
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /sendGroupMessage
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
使用此方法向指定群发送消息
|
|
|
|
|
|
|
|
|
|
#### 请求
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSession",
|
|
|
|
|
"target": 987654321,
|
|
|
|
|
"qq": 1234567890,
|
|
|
|
|
"group": 987654321,
|
|
|
|
|
"urls": [
|
|
|
|
|
"https://xxx.yyy.zzz/",
|
|
|
|
|
"https://aaa.bbb.ccc/"
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ------------ | ------ | ----- | ----------- | ---------------------------------- |
|
|
|
|
|
| sessionKey | String | false | YourSession | 已经激活的Session |
|
|
|
|
|
| target | Long | true | 987654321 | 发送对象的QQ号或群号,可能存在歧义 |
|
|
|
|
|
| qq | Long | true | 123456789 | 发送对象的QQ号 |
|
|
|
|
|
| group | Long | true | 987654321 | 发送对象的群号 |
|
|
|
|
|
| urls | Array | false | [] | 是一个url字符串构成的数组 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 图片的imageId数组
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
[
|
|
|
|
|
"{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}.jpg",
|
|
|
|
|
"{YYYYYYYY-YYYY-YYYY-YYYY-YYYYYYYYYYYY}.jpg"
|
|
|
|
|
]
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 图片文件上传
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /sendGroupMessage
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
使用此方法上传图片文件至服务器并返回ImageId
|
|
|
|
|
|
|
|
|
|
#### 请求
|
|
|
|
|
|
|
|
|
|
Content-Type:multipart/form-data
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ------------ | ------ | ----- | ----------- | ---------------------------------- |
|
|
|
|
|
| sessionKey | String | false | YourSession | 已经激活的Session |
|
|
|
|
|
| type | String | false | "friend " | "friend" 或 "group" |
|
|
|
|
|
| img | File | false | - | 图片文件 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#### 响应: 图片的imageId(好友图片与群聊图片Id不同)
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
{XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX}.jpg
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
### 获取Bot收到的消息
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[GET] /fetchMessage?sessionKey=YourSessionKey&count=10
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ----- | -------------- | --------------- |
|
|
|
|
|
| sessionKey | false | YourSessionKey | 你的session key |
|
|
|
|
|
| count | false | 10 | 获取消息的数量 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回JSON对象
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
[{
|
|
|
|
|
"type": "GroupMessage", // 消息类型:GroupMessage或FriendMessage
|
|
|
|
|
"messageChain": [{ // 消息链,是一个消息对象构成的数组
|
2020-02-14 23:35:58 +08:00
|
|
|
|
"type": "Source",
|
|
|
|
|
"uid": 123456
|
|
|
|
|
},{
|
2020-02-05 00:12:21 +08:00
|
|
|
|
"type": "Plain",
|
|
|
|
|
"text": "Miral牛逼"
|
|
|
|
|
}],
|
|
|
|
|
"sender": { // 发送者信息
|
|
|
|
|
"id": 123456789, // 发送者的QQ号码
|
|
|
|
|
"memberName": "化腾", // 发送者的群名片
|
|
|
|
|
"permission": "MEMBER", // 发送者的群限权:OWNER、ADMINISTRATOR或MEMBER
|
|
|
|
|
"group": { // 消息发送群的信息
|
|
|
|
|
"id": 1234567890, // 发送群的群号
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"name": "Miral Technology", // 发送群的群名称
|
|
|
|
|
"permission": "MEMBER" // 发送群中,Bot的群限权
|
2020-02-05 00:12:21 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
"type": "FriendMessage", // 消息类型:GroupMessage或FriendMessage
|
|
|
|
|
"messageChain": [{ // 消息链,是一个消息对象构成的数组
|
|
|
|
|
"type": "Plain",
|
|
|
|
|
"text": "Miral牛逼"
|
|
|
|
|
}],
|
|
|
|
|
"sender": { // 发送者信息
|
|
|
|
|
"id": 1234567890, // 发送者的QQ号码
|
|
|
|
|
"nickName": "", // 发送者的昵称
|
|
|
|
|
"remark": "" // 发送者的备注
|
|
|
|
|
}
|
|
|
|
|
}]
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 消息类型一览
|
|
|
|
|
|
|
|
|
|
#### 消息是构成消息链的基本对象,目前支持的消息类型有
|
|
|
|
|
|
|
|
|
|
+ [x] At,@消息
|
2020-02-14 21:25:34 +08:00
|
|
|
|
+ [x] AtAll,@全体成员
|
2020-02-05 00:12:21 +08:00
|
|
|
|
+ [x] Face,表情消息
|
|
|
|
|
+ [x] Plain,文字消息
|
2020-02-14 21:25:34 +08:00
|
|
|
|
+ [x] Image,图片消息
|
2020-02-05 00:12:21 +08:00
|
|
|
|
+ [ ] Xml,Xml卡片消息
|
|
|
|
|
+ [ ] 敬请期待
|
|
|
|
|
|
2020-02-14 23:35:58 +08:00
|
|
|
|
#### Source
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"type": "Source",
|
|
|
|
|
"uid": 123456
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 说明 |
|
|
|
|
|
| ---- | ---- | ------------------------------------------------------------ |
|
|
|
|
|
| uid | Long | 消息的识别号,用于引用回复(Source类型只在群消息中返回,且永远为chain的第一个元素) |
|
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
#### At
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"type": "At",
|
|
|
|
|
"target": 123456,
|
|
|
|
|
"display": "@Mirai"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 说明 |
|
|
|
|
|
| ------- | ------ | ------------------------- |
|
|
|
|
|
| target | Long | 群员QQ号 |
|
|
|
|
|
| display | String | @时显示的文本如:"@Mirai" |
|
|
|
|
|
|
2020-02-14 21:25:34 +08:00
|
|
|
|
#### AtAll
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"type": "AtAll"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 说明 |
|
|
|
|
|
| ------- | ------ | ------------------------- |
|
|
|
|
|
| - | - | - |
|
|
|
|
|
|
2020-02-05 00:12:21 +08:00
|
|
|
|
#### Face
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"type": "Face",
|
2020-02-08 20:15:34 +08:00
|
|
|
|
"faceId": 123
|
2020-02-05 00:12:21 +08:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 说明 |
|
|
|
|
|
| ------ | ---- | ---------- |
|
2020-02-08 20:15:34 +08:00
|
|
|
|
| faceId | Int | QQ表情编号 |
|
2020-02-05 00:12:21 +08:00
|
|
|
|
|
|
|
|
|
#### Plain
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"type": "Plain",
|
|
|
|
|
"text": "Mirai牛逼"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 说明 |
|
|
|
|
|
| ---- | ------ | -------- |
|
|
|
|
|
| text | String | 文字消息 |
|
|
|
|
|
|
|
|
|
|
#### Image
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"type": "Image"
|
|
|
|
|
// 暂时不支持Image
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 说明 |
|
|
|
|
|
| ---- | ---- | ---- |
|
|
|
|
|
| | | |
|
|
|
|
|
|
|
|
|
|
#### Xml
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"type": "Xml",
|
|
|
|
|
"xml": "XML"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 类型 | 说明 |
|
|
|
|
|
| ---- | ------ | ------- |
|
2020-02-05 23:40:36 +08:00
|
|
|
|
| xml | String | XML文本 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 管理相关
|
|
|
|
|
|
|
|
|
|
### 获取好友列表
|
|
|
|
|
|
|
|
|
|
使用此方法获取bot的好友列表
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[GET] /friendList?sessionKey=YourSessionKey
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ----- | -------------- | --------------- |
|
|
|
|
|
| sessionKey | false | YourSessionKey | 你的session key |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回JSON对象
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
[{
|
|
|
|
|
"id":123456789,
|
|
|
|
|
"nickName":"",
|
|
|
|
|
"remark":""
|
|
|
|
|
},{
|
|
|
|
|
"id":987654321,
|
|
|
|
|
"nickName":"",
|
|
|
|
|
"remark":""
|
|
|
|
|
}]
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 获取群列表
|
|
|
|
|
|
|
|
|
|
使用此方法获取bot的群列表
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[GET] /groupList?sessionKey=YourSessionKey
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ----- | -------------- | --------------- |
|
|
|
|
|
| sessionKey | false | YourSessionKey | 你的session key |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回JSON对象
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
[{
|
|
|
|
|
"id":123456789,
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"name":"群名1",
|
|
|
|
|
"permission": "MEMBER"
|
2020-02-05 23:40:36 +08:00
|
|
|
|
},{
|
|
|
|
|
"id":987654321,
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"name":"群名2",
|
|
|
|
|
"permission": "MEMBER"
|
2020-02-05 23:40:36 +08:00
|
|
|
|
}]
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 获取群成员列表
|
|
|
|
|
|
|
|
|
|
使用此方法获取bot指定群种的成员列表
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[GET] /memberList?sessionKey=YourSessionKey
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ----- | -------------- | --------------- |
|
|
|
|
|
| sessionKey | false | YourSessionKey | 你的session key |
|
|
|
|
|
| target | false | 123456789 | 指定群的群号 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回JSON对象
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
[{
|
|
|
|
|
"id":1234567890,
|
|
|
|
|
"memberName":"",
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"permission":"MEMBER",
|
2020-02-05 23:40:36 +08:00
|
|
|
|
"group":{
|
|
|
|
|
"id":12345,
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"name":"群名1",
|
|
|
|
|
"permission": "MEMBER"
|
|
|
|
|
}
|
2020-02-05 23:40:36 +08:00
|
|
|
|
},{
|
|
|
|
|
"id":9876543210,
|
|
|
|
|
"memberName":"",
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"permission":"OWNER",
|
2020-02-05 23:40:36 +08:00
|
|
|
|
"group":{
|
|
|
|
|
"id":54321,
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"name":"群名2",
|
|
|
|
|
"permission": "MEMBER"
|
|
|
|
|
}
|
2020-02-05 23:40:36 +08:00
|
|
|
|
}]
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 群全体禁言
|
|
|
|
|
|
2020-02-08 20:15:34 +08:00
|
|
|
|
使用此方法令指定群进行全体禁言(需要有相关限权)
|
2020-02-05 23:40:36 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /muteAll
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"sessionKey": "YourSessionKey",
|
|
|
|
|
"target": 123456789,
|
2020-02-05 23:40:36 +08:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ----- | ------ | ---------------- | --------------- |
|
|
|
|
|
| sessionKey | false | String | "YourSessionKey" | 你的session key |
|
|
|
|
|
| target | false | Long | 123456789 | 指定群的群号 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 群解除全体禁言
|
|
|
|
|
|
2020-02-08 20:15:34 +08:00
|
|
|
|
使用此方法令指定群解除全体禁言(需要有相关限权)
|
2020-02-05 23:40:36 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /unmuteAll
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
同全体禁言
|
|
|
|
|
|
|
|
|
|
#### 响应
|
|
|
|
|
|
|
|
|
|
同全体禁言
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 群禁言群成员
|
|
|
|
|
|
2020-02-08 20:15:34 +08:00
|
|
|
|
使用此方法指定群禁言指定群员(需要有相关限权)
|
2020-02-05 23:40:36 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /mute
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"sessionKey": "YourSessionKey",
|
|
|
|
|
"target": 123456789,
|
2020-02-08 20:15:34 +08:00
|
|
|
|
"memberId": 987654321,
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"time": 1800
|
2020-02-05 23:40:36 +08:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ----- | ------ | ---------------- | ------------------------------------- |
|
|
|
|
|
| sessionKey | false | String | "YourSessionKey" | 你的session key |
|
|
|
|
|
| target | false | Long | 123456789 | 指定群的群号 |
|
2020-02-08 20:15:34 +08:00
|
|
|
|
| memberId | false | Long | 987654321 | 指定群员QQ号 |
|
2020-02-05 23:40:36 +08:00
|
|
|
|
| time | true | Int | 1800 | 禁言时长,单位为秒,最多30天,默认为0 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 群解除群成员禁言
|
|
|
|
|
|
2020-02-08 20:15:34 +08:00
|
|
|
|
使用此方法令指定群解除全体禁言(需要有相关限权)
|
2020-02-05 23:40:36 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /unmute
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
2020-02-06 18:27:34 +08:00
|
|
|
|
```json5
|
2020-02-05 23:40:36 +08:00
|
|
|
|
{
|
2020-02-06 18:27:34 +08:00
|
|
|
|
"sessionKey": "YourSessionKey",
|
|
|
|
|
"target": 123456789,
|
2020-02-08 20:15:34 +08:00
|
|
|
|
"memberId": 987654321
|
2020-02-05 23:40:36 +08:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 响应
|
|
|
|
|
|
|
|
|
|
同群禁言群成员
|
|
|
|
|
|
2020-02-06 18:27:34 +08:00
|
|
|
|
|
|
|
|
|
|
2020-02-08 20:15:34 +08:00
|
|
|
|
### 移除群成员
|
|
|
|
|
|
|
|
|
|
使用此方法移除指定群成员(需要有相关限权)
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /kick
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSessionKey",
|
|
|
|
|
"target": 123456789,
|
|
|
|
|
"memberId": 987654321,
|
|
|
|
|
"msg": "您已被移出群聊"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ---------- | ----- | ------ | ---------------- | --------------- |
|
|
|
|
|
| sessionKey | false | String | "YourSessionKey" | 你的session key |
|
|
|
|
|
| target | false | Long | 123456789 | 指定群的群号 |
|
|
|
|
|
| memberId | false | Long | 987654321 | 指定群员QQ号 |
|
|
|
|
|
| msg | true | String | "" | 信息 |
|
|
|
|
|
|
|
|
|
|
#### 响应
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-02-06 18:27:34 +08:00
|
|
|
|
### 群设置
|
|
|
|
|
|
2020-02-08 20:15:34 +08:00
|
|
|
|
使用此方法修改群设置(需要有相关限权)
|
2020-02-06 18:27:34 +08:00
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /groupConfig
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSessionKey",
|
|
|
|
|
"target": 123456789,
|
|
|
|
|
"config": {
|
|
|
|
|
"name": "群名称",
|
|
|
|
|
"announcement": "群公告",
|
|
|
|
|
"confessTalk": true,
|
|
|
|
|
"allowMemberInvite": true,
|
|
|
|
|
"autoApprove": true,
|
|
|
|
|
"anonymousChat": true
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ----------------- | ----- | ------- | ---------------- | -------------------- |
|
|
|
|
|
| sessionKey | false | String | "YourSessionKey" | 你的session key |
|
|
|
|
|
| target | false | Long | 123456789 | 指定群的群号 |
|
|
|
|
|
| config | false | Object | {} | 群设置 |
|
|
|
|
|
| name | true | String | "Name" | 群名 |
|
|
|
|
|
| announcement | true | Boolean | true | 群公告 |
|
|
|
|
|
| confessTalk | true | Boolean | true | 是否开启坦白说 |
|
|
|
|
|
| allowMemberInvite | true | Boolean | true | 是否运行群员邀请 |
|
|
|
|
|
| autoApprove | true | Boolean | true | 是否开启自动审批入群 |
|
|
|
|
|
| anonymousChat | true | Boolean | true | 是否允许匿名聊天 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 获取群设置
|
|
|
|
|
|
|
|
|
|
使用此方法获取群设置
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[Get] /groupConfig?sessionKey=YourSessionKey&target=123456789
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ----------------- | ----- | ------- | ---------------- | -------------------- |
|
|
|
|
|
| sessionKey | false | String | YourSessionKey | 你的session key |
|
|
|
|
|
| target | false | Long | 123456789 | 指定群的群号 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#### 响应
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"name": "群名称",
|
|
|
|
|
"announcement": "群公告",
|
|
|
|
|
"confessTalk": true,
|
|
|
|
|
"allowMemberInvite": true,
|
|
|
|
|
"autoApprove": true,
|
|
|
|
|
"anonymousChat": true
|
|
|
|
|
}
|
|
|
|
|
```
|
2020-02-08 20:15:34 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 修改群员资料
|
|
|
|
|
|
|
|
|
|
使用此方法修改群员资料(需要有相关限权)
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[POST] /memberInfo
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"sessionKey": "YourSessionKey",
|
|
|
|
|
"target": 123456789,
|
|
|
|
|
"memberId": 987654321,
|
|
|
|
|
"info": {
|
|
|
|
|
"name": "群名片",
|
|
|
|
|
"specialTitle": "群头衔"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ----------------- | ----- | ------- | ---------------- | -------------------- |
|
|
|
|
|
| sessionKey | false | String | "YourSessionKey" | 你的session key |
|
|
|
|
|
| target | false | Long | 123456789 | 指定群的群号 |
|
|
|
|
|
| memberId | false | Long | 987654321 | 群员QQ号 |
|
|
|
|
|
| info | false | Object | {} | 群员资料 |
|
|
|
|
|
| name | true | String | "Name" | 群名片,即群昵称 |
|
|
|
|
|
| specialTitle | true | String | "Title" | 群头衔 |
|
|
|
|
|
|
|
|
|
|
#### 响应: 返回统一状态码
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"code": 0,
|
|
|
|
|
"msg": "success"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 获取群员资料
|
|
|
|
|
|
|
|
|
|
使用此方法获取群员资料
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
[Get] /groupConfig?sessionKey=YourSessionKey&target=123456789
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 请求:
|
|
|
|
|
|
|
|
|
|
| 名字 | 可选 | 类型 | 举例 | 说明 |
|
|
|
|
|
| ----------------- | ----- | ------- | ---------------- | -------------------- |
|
|
|
|
|
| sessionKey | false | String | YourSessionKey | 你的session key |
|
|
|
|
|
| target | false | Long | 123456789 | 指定群的群号 |
|
|
|
|
|
| memberId | false | Long | 987654321 | 群员QQ号 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#### 响应
|
|
|
|
|
|
|
|
|
|
```json5
|
|
|
|
|
{
|
|
|
|
|
"name": "群名片",
|
|
|
|
|
"announcement": "群头衔"
|
|
|
|
|
}
|
|
|
|
|
```
|