mica mqtt Http Api 接口
注意: 从 mica-mqtt 2.5.x 开始默认的 http api 端口由 8083 改为了 18083。
HTTP 状态码 (status codes)
接口在调用成功时总是返回 200 OK,响应内容则以 JSON 格式返回。
可能的状态码如下:
| Status Code | Description | 
|---|---|
| 200 | 成功,返回的 JSON 数据将提供更多信息 | 
| 400 | 客户端请求无效,例如请求体或参数错误 | 
| 401 | 客户端未通过服务端认证,使用无效的身份验证凭据可能会发生 | 
| 404 | 找不到请求的路径或者请求的对象不存在 | 
| 405 | 请求方法错误 | 
| 500 | 服务端处理请求时发生内部错误 | 
返回码 (result codes)
接口的响应消息体为 JSON 格式,其中总是包含返回码 code。
可能的返回码如下:
| Return Code | Description | 
|---|---|
| 1 | 成功 | 
| 101 | 关键请求参数缺失 | 
| 102 | 请求参数错误 | 
| 103 | 用户名或密码错误 | 
| 104 | 请求方法错误 | 
| 105 | 未知错误 | 
获取所有 api 接口列表
GET /api/v1/endpoints
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 1 | 
| data | Array | 接口列表 | 
| method | String | 方法名 | 
| path | String | 路径 | 
Examples:
$ curl -i --basic -u mica:mica "http://localhost:18083/api/v1/endpoints"
{
    "data": [
        {
            "method": "GET",
            "path": "/api/v1/endpoints"
        },
        {
            "method": "GET",
            "path": "/api/v1/clients"
        },
        {
            "method": "POST",
            "path": "/api/v1/mqtt/unsubscribe"
        },
        {
            "method": "GET",
            "path": "/api/v1/clients/info"
        },
        {
            "method": "GET",
            "path": "/api/v1/stats"
        },
        {
            "method": "POST",
            "path": "/api/v1/mqtt/publish/batch"
        },
        {
            "method": "POST",
            "path": "/api/v1/mqtt/subscribe/batch"
        },
        {
            "method": "GET",
            "path": "/api/v1/client/subscriptions"
        },
        {
            "method": "POST",
            "path": "/api/v1/mqtt/publish"
        },
        {
            "method": "POST",
            "path": "/api/v1/mqtt/unsubscribe/batch"
        },
        {
            "method": "POST",
            "path": "/api/v1/mqtt/subscribe"
        },
        {
            "method": "POST",
            "path": "/api/v1/clients/delete"
        }
    ],
    "code": 1
}消息发布
POST /api/v1/mqtt/publish
发布 MQTT 消息。
Parameters (json):
| Name | Type | Required | Default | Description | 
|---|---|---|---|---|
| topic | String | Required | 主题,消息会按 topic 订阅投递 | |
| clientId | String | Required | 客户端标识符,不为空参数即可,无实际意义,建议可以取名 httpApi | |
| payload | String | Required | 消息正文 | |
| encoding | String | Optional | plain | 消息正文使用的编码方式,目前仅支持 目前仅支持 plain、hex、base64 | 
| qos | Integer | Optional | 0 | QoS 等级 | 
| retain | Boolean | Optional | false | 是否为保留消息 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Examples:
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/mqtt/publish" -d '{"topic":"a/b/c","payload":"Hello World","qos":1,"retain":false,"clientId":"example"}'
{"code":1}主题订阅
POST /api/v1/mqtt/subscribe
订阅 MQTT 主题。
Parameters (json):
| Name | Type | Required | Default | Description | 
|---|---|---|---|---|
| topic | String | Required | 主题 | |
| clientId | String | Required | 客户端标识符 | |
| qos | Integer | Optional | 0 | QoS 等级 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Examples:
同时订阅 a, b, c 三个主题
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/mqtt/subscribe" -d '{"topic":"a/b/c","qos":1,"clientId":"example"}'
{"code":1}POST /api/v1/mqtt/unsubscribe
取消订阅。
Parameters (json):
| Name | Type | Required | Default | Description | 
|---|---|---|---|---|
| topic | String | Required | 主题 | |
| clientId | String | Required | 客户端标识符 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Examples:
取消订阅 a 主题
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/mqtt/unsubscribe" -d '{"topic":"a","clientId":"example"}'
{"code":1}消息批量发布
POST /api/v1/mqtt/publish/batch
批量发布 MQTT 消息。
Parameters (json):
| Name | Type | Required | Default | Description | 
|---|---|---|---|---|
| [0].topic | String | Required | 主题,消息按订阅投递 | |
| [0].clientId | String | Required | 客户端标识符,不为空参数即可,无实际意义,建议可以取名 httpApi | |
| [0].payload | String | Required | 消息正文 | |
| [0].encoding | String | Optional | plain | 消息正文使用的编码方式,目前仅支持 plain、hex、base64 | 
| [0].qos | Integer | Optional | 0 | QoS 等级 | 
| [0].retain | Boolean | Optional | false | 是否为保留消息 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Examples:
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/mqtt/publish/batch" -d '[{"topic":"a/b/c","payload":"Hello World","qos":1,"retain":false,"clientId":"example"},{"topic":"a/b/c","payload":"Hello World Again","qos":0,"retain":false,"clientId":"example"}]'
{"code":1}主题批量订阅
POST /api/v1/mqtt/subscribe/batch
批量订阅 MQTT 主题。
Parameters (json):
| Name | Type | Required | Default | Description | 
|---|---|---|---|---|
| [0].topic | String | Required | 主题 | |
| [0].clientId | String | Required | 客户端标识符 | |
| [0].qos | Integer | Optional | 0 | QoS 等级 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Examples:
一次性订阅 a, b, c 三个主题
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/mqtt/subscribe/batch" -d '[{"topic":"a","qos":1,"clientId":"example"},{"topic":"b","qos":1,"clientId":"example"},{"topic":"c","qos":1,"clientId":"example"}]'
{"code":1}POST /api/v1/mqtt/unsubscribe/batch
批量取消订阅。
Parameters (json):
| Name | Type | Required | Default | Description | 
|---|---|---|---|---|
| [0].topic | String | Required | 主题 | |
| [0].clientId | String | Required | 客户端标识符 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Examples:
一次性取消订阅 a, b 主题
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/mqtt/unsubscribe/batch" -d '[{"topic":"a","clientId":"example"},{"topic":"b","clientId":"example"}]'
{"code":1}获取客户端详情
GET /api/v1/clients/info
Query Parameters:
| Name | Type | Required | Description | 
|---|---|---|---|
| clientId | String | True | ClientID | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
| clientId | String | clientId | 
| username | String | 用户名 | 
| connected | Boolen | 是否已经连接 | 
| createdAt | Long | 连接的时间 | 
| connectedAt | Long | 连接成功时间 | 
Examples:
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/clients/info?clientId=mqttx_5fe4cfcf"
{"code":1,"data":{"clientId":"mqttx_5fe4cfcf","connected":true,"connectedAt":1681792417835,"createdAt":1681792417835,"ipAddress":"127.0.0.1","port":11852,"protoName":"MQTT","protoVer":5}}分页获取客户端
GET /api/v1/clients
Query Parameters:
| Name | Type | Required | Description | 
|---|---|---|---|
| _page | int | False | Page 默认1 | 
| _limit | int | False | 分页大小 默认10000 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
| pageNumber | Integer | 当前页码 | 
| pageSize | Integer | 分页大小 | 
| totalRow | Integer | 分页数 | 
| clientId | String | clientId | 
| username | String | 用户名 | 
| connected | Boolen | 是否已经连接 | 
| createdAt | Long | 连接的时间 | 
| connectedAt | Long | 连接成功时间 | 
Examples:
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/clients?_page=1&_limit=100"
{"data":{"list":[{"clientId":"mqttx_5fe4cfcf","connected":true,"protoName":"MQTT","protoVer":5,"ipAddress":"127.0.0.1","port":11852,"connectedAt":1681792417835,"createdAt":1681792417835}],"pageNumber":1,"pageSize":1,"totalRow":1},"code":1}踢出指定客户端
POST /api/v1/clients/delete
踢出指定客户端。注意踢出客户端操作会将连接与会话一并终结。
Query Parameters:
| Name | Type | Required | Description | 
|---|---|---|---|
| clientId | String | True | ClientID | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
Examples:
由于客户端可能会重连,所以还会连上了。如果需要永久踢出需要自行开发黑名单。
$ curl -i --basic -u mica:mica -X POST "http://localhost:18083/api/v1/clients/delete?clientId=123"
{"code":1}获取客户端订阅情况
GET /api/v1/client/subscriptions
获取指定客户端订阅详情。
Query Parameters:
| Name | Type | Required | Description | 
|---|---|---|---|
| clientId | String | True | ClientID | 
Success Response Body (JSON):
| Name | Type | Description | 
|---|---|---|
| code | Integer | 0 | 
| data | Array | [] | 
| topicFilter | String | |
| clientId | String | |
| mqttQoS | Integer | 0 | 
Examples:
$ curl -i --basic -u mica:mica "http://127.0.0.1:8083/api/v1/client/subscriptions?clientId=123"
{
  "code": 1,
  "data": [
    {
      "clientId": "123",
      "mqttQoS": 0,
      "topicFilter": "#"
    },
    {
      "clientId": "123",
      "mqttQoS": 0,
      "topicFilter": "testtopic/#"
    }
  ]
}