On this page
网关API通信
一、环境准备
1.测试环境
1
2
3
4
5
6
7
8
9
10
| # ThingsBoard
http://192.168.202.188:8080/login
# Node-RED
http://192.168.202.188:1880
设备名称:Node-RED-gateway
访问令牌:y0b9w7P2dSIR2AKn7Dl4
Nodered流程: TB-gateway
|
2.创建网关
data:image/s3,"s3://crabby-images/2a23f/2a23f1bacb90a49a061995f41f46b7eda15ba866" alt=""
3.创建Node-RED流程
data:image/s3,"s3://crabby-images/14434/14434634666c12a65e6bbc538c2e1eef65024aa8" alt=""
二、设备链接
1.Connect
1
2
3
4
| # 发布主题
v1/gateway/connect
{"device":"Device A"}
|
data:image/s3,"s3://crabby-images/44b1f/44b1fe8bcee706a3846b08397a51f55aa1612033" alt=""
data:image/s3,"s3://crabby-images/e50a2/e50a2e1752824a2c6dff40b321598e1f78159054" alt=""
data:image/s3,"s3://crabby-images/1a308/1a308bb65c8715f2b0a4ad082699519f34a6c358" alt=""
data:image/s3,"s3://crabby-images/e0e15/e0e1560b6d8b112bec4971f5b3584d0741ac9b53" alt=""
data:image/s3,"s3://crabby-images/dfd9a/dfd9aa12fb30bb916ab05750e76923a917367d35" alt=""
data:image/s3,"s3://crabby-images/0f504/0f504884bf12a8cf2cb21c26e80e7509ca101c43" alt=""
2.Disconnect
1
2
3
| v1/gateway/disconnect
{"device":"Device A"}
|
data:image/s3,"s3://crabby-images/0f504/0f504884bf12a8cf2cb21c26e80e7509ca101c43" alt=""
data:image/s3,"s3://crabby-images/7fcc5/7fcc5b28502e08f0dbd526ece573c3db6e1ba79c" alt=""
三、属性
1.发布属性到服务端
将客户端设备属性发布到ThingsBoard服务器节点。
1
2
3
| Topic: v1/gateway/attributes
Message: {"Device A":{"attribute1":"value1", "attribute2": 42}, "Device B":{"attribute1":"value1", "attribute2": 42}}
|
data:image/s3,"s3://crabby-images/08faf/08faf1db35c0a486e1ea85526f1c99eefea74f1f" alt=""
data:image/s3,"s3://crabby-images/57541/5754178e9c9e2b81482a2ed10bb8b3775890c9e4" alt=""
data:image/s3,"s3://crabby-images/729f0/729f04a3aa5a674968acf536c667a534e4b7c094" alt=""
data:image/s3,"s3://crabby-images/eaa26/eaa26d1aab7542a2c4cf4a2ce55f88befbe63666" alt=""
2.请求属性从服务端
向ThingsBoard服务器节点请求客户端或共享设备属性。
请向以下主题发送PUBLISH消息:
1
2
| Topic: v1/gateway/attributes/request
Message: {"id": $request_id, "device": "Device A", "client": true, "key": "attribute1"}
|
其中$request_id是您的整数请求标识符,设备A是您的设备名称,client标识客户端或共享属性范围,key是属性键。
在发送PUBLISH消息和请求之前,客户端需要订阅
1
| Topic: v1/gateway/attributes/response
|
并期望具有以下格式的结果的消息:
1
| Message: {"id": $request_id, "device": "Device A", "value": "value1"}
|
data:image/s3,"s3://crabby-images/f18df/f18dfb811eaf5a085d4e1e4855bd52e610a11ace" alt=""
data:image/s3,"s3://crabby-images/53f11/53f117c482bcf1bda80ff9cb85aa8899af88c181" alt=""
data:image/s3,"s3://crabby-images/d97ae/d97ae71759be58dedb5f8f482f727e7d2eef775b" alt=""
data:image/s3,"s3://crabby-images/a5391/a53918c6d2f1e33133e9473da074641006240958" alt=""
data:image/s3,"s3://crabby-images/acbaf/acbaf4cc23416c3fe3eb1e96f4a0dd904ba062a8" alt=""
3.订阅属性更新从服务端
订阅共享设备属性更改,请向以下主题发送subscribe消息:
并期望具有以下格式的结果的消息:
1
| Message: {"device": "Device A", "data": {"attribute1": "value1", "attribute2": 42}}
|
data:image/s3,"s3://crabby-images/87746/877467cbb9375be043703f2a93ee4881c1490fa6" alt=""
data:image/s3,"s3://crabby-images/afedf/afedfd7f4fb9f81a27fc05152c96e12a8e976e14" alt=""
data:image/s3,"s3://crabby-images/9e86c/9e86c467e17d96d867c4463367af262f20068dde" alt=""
data:image/s3,"s3://crabby-images/18ae4/18ae4fa2a660537047036a1c962b2ccc6dffd5f8" alt=""
四、遥测
将设备遥测发布到ThingsBoard服务器节点,请向以下主题发送publish消息:
1
| Topic: v1/gateway/telemetry
|
Message:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
| {
"Device A": [
{
"ts": 1483228800000,
"values": {
"temperature": 42,
"humidity": 80
}
},
{
"ts": 1483228801000,
"values": {
"temperature": 43,
"humidity": 82
}
}
],
"Device B": [
{
"ts": 1483228800000,
"values": {
"temperature": 42,
"humidity": 80
}
}
]
}
|
data:image/s3,"s3://crabby-images/598ea/598eacfceccbf07c674f3343cc2f4fcb5edd031e" alt=""
data:image/s3,"s3://crabby-images/e7bfc/e7bfc78678a8d531ff9132a07201b206e8d0c27b" alt=""
data:image/s3,"s3://crabby-images/fff11/fff11cf8528cb462e5c3ad60f353d91461ca78b5" alt=""
data:image/s3,"s3://crabby-images/ece4a/ece4a1ec4025a6d3967ba1535e56d69a12026043" alt=""
五、服务端RPC
从服务器订阅RPC命令,请向以下主题发送subscribe消息:
并期望具有以下格式的单个命令的消息:
1
| {"device": "Device A", "data": {"id": $request_id, "method": "toggle_gpio", "params": {"pin":1}}}
|
一旦设备处理了命令,网关就可以使用以下格式发回命令:
1
| {"device": "Device A", "id": $request_id, "data": {"success": true}}
|
data:image/s3,"s3://crabby-images/85a4a/85a4abb8aa943769f6dd720bcac3f18c19ba5c1d" alt=""
data:image/s3,"s3://crabby-images/e0aff/e0aff3c9a45ee13f64ed962f05bd91350caf5205" alt=""
data:image/s3,"s3://crabby-images/96a78/96a788fd625d983f9bf500b7783ce99b140212fc" alt=""
六、总结
data:image/s3,"s3://crabby-images/1f449/1f449305098b224f146fd0819f86602ad9dc1a9f" alt=""