http://docs.opencloud.aqara.cn/development/gateway-LAN-communication/

https://github.com/aqara/opencloud-docs/

概述

绿米智能网关支持局域网通讯功能,通过开放局域网通信API,允许开发者通过局域网通信对网关下各ZigBee子设备(传感器、控制器等)进行管理。

相比HTTP通讯,局域网通讯的速度更快,控制延迟更低。但是,局域网对接方式的开发成本更高,需要一台支持开发的第三方网关,并且开发者有嵌入式开发经验。

目前主要开放的API功能有:

  • 发现与查询设备
  • 设备状态上报
  • 对设备进行读写操作
  • 设备心跳上报

注意:如需使用多功能网关,请参考网关局域网通信协议V1.0

修订记录

介绍网关局域网通信协议各版本的主要变更内容。

更新时间 文档版本 更新日志
2018.07.16 V2.0.2 新增:空调伴侣空调状态上报和控制功能,空调伴侣继电器控制功能;新增:RGB控制器和空调温控器
2018.05.18 V2.0.1 新增:魔方传感器 (sensor_cube.aqgl01)、墙壁插座(ctrl_86plug.aq1)、墙壁开关(ctrl_ln1.aq1)
2017.10.09 V2.0.1 修改:水浸传感器的属性上报
2017.09.20 V2.0.0 修改:基本的JSON格式变更;部分设备的model值和属性名称变更;对于属性的取值类型,模拟量统一取值为数值型。

加密机制

局域网通信采用key加密方式,需在APP上获取随机生成的网关KEY,该KEY使用AES-CBC 128加密,为16个字节长度的字符串。开启局域网通信协议并拥有该网关的KEY后,才能与该网关进行局域网通信。

注意:AES-CBC 128初始向量定义为:unsigned char const AES_KEY_IV[16] = {0x17, 0x99, 0x6d, 0x09, 0x3d, 0x28, 0xdd, 0xb3, 0xba, 0x69, 0x5a, 0x2e, 0x6f, 0x58, 0x56, 0x2e}。

获取网关KEY的具体操作如下:

1、打开Aqara APP,选择需要进行局域网通信的网关设备;

注意:当前仅“升级版空调伴侣”支持局域网通信协议功能。

2、默认情况下,此页面不显示“局域网协议”,需连续点击"设备类型"10次才可显示。

3、开启“局域网协议”,获取随机KEY,单击“确定”。

设备发现与查询

发现网关设备

设备发现采用不加密方式,使用组播(IP:224.0.0.50,Port:4321,Protocal:UDP),在局域网中发现网关设备。

以组播方式发送“whois”命令:

{
"cmd":"whois"
}

所有网关收到“whois”命令都要应答且回复自己的IP信息,以单播的形式回复:

{
"cmd":"iam",
"ip":"192.168.0.42", //网关IP地址
"protocal":"UDP",
"port":"9898",
"model":"gateway.aq1", //网关设备类型
......
}

查询子设备列表

命令以单播方式发送给网关的UDP 9898端口,用来获取网关中有哪些子设备。

以单播方式向网关发送“discovery”命令:

{
"cmd":"discovery"
}

网关以单播方式回复,返回子设备的设备id和model值:

{
"cmd":"discovery_rsp",
"sid":"158d323123c9d9", //sid为网关did
"token":"TahkC7dalbIhXG22", //网关生成的随机字符串
"dev_list":[{"sid":"xxxxxxxx","model":"plug"},
{"sid":"xxxxxxxx","model":"sensor_switch.aq2"}] //sid为子设备did
}

注意:“token”为网关生成的随机字符串,每10s刷新一次,在未收到设备心跳上报的token前,用户可用此token来生成写设备时的“key”。

设备状态上报

当设备状态发生变化时,使用“report”命令以组播方式发送给(IP:224.0.0.50,Port:9898)上报属性状态,如门窗传感器的打开或关闭信息。利用上报的属性状态,用户可以实现智能联动操作,如关闭窗户即开启空调。

例如:

门窗传感器上报窗户的开关状态,格式如下:

{
"cmd":"report",
"model":"sensor_magnet.aq2",
"sid":"xxxxxxxx",
"params":[{"window_status":"open"}]
}

设备心跳上报

网关心跳

网关心跳以组播方式发送给(IP:224.0.0.50,Port:9898)。网关每10秒钟发送一次心跳报文,用来告诉PC网关正常工作。若间隔65s以上未收到心跳包即表示网关处于离线状态。网关设备心跳格式如下:

{
"cmd":"heartbeat",
"model":"gateway.v3",
"sid":"xxxxxxxx",
"token":"1234567890abcdef", //网关生成的随机字符串
"params":[{"ip":"172.22.4.130"}] //网关IP地址
}

注意:“token”为网关生成的随机字符串,每10s刷新一次,可用此token来生成写设备时的“key”。

子设备心跳

子设备心跳以组播方式发送给(IP:224.0.0.50,Port:9898)。子设备通过心跳告诉PC:子设备正常工作(心跳上报频率:睡眠设备是每60分钟一次,插电设备是每10分钟一次)。子设备心跳格式如下:

{
"cmd":"heartbeat",
"model":"sensor_magnet.aq2",
"sid":"xxxxxxxx",
"params":[{"window_status":"open"}]
}

子设备心跳中可能包含子设备的属性状态,如格式中的"window_status":"open"。在设置心跳的时候,需看此属性状态的具体使用场景。

例如:开窗关空调场景,可以使用上面的心跳(有可能正常的report报文丢失,心跳报文可以补救)。但关窗开空调场景,就不能使用上面的心跳。因为有可能人离开的时候把空调关了,但心跳报文又让空调打开,很浪费电。

因此,针对心跳报文的使用,用户可根据使用需要自行决定是否用心跳做触发。

设备的读写操作

读设备

使用“read”命令以单播方式发送给网关的UDP 9898端口。用户可以用主动读取各设备的属性状态,网关返回该设备的全部属性信息。

例如:

读取墙壁开关的状态:

{
"cmd":"read",
"sid":"xxxxxxxx" //墙壁开关did
}

网关以单播方式回复,格式如下:

{
"cmd":"read_rsp",
"model":"ctrl_neutral2",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"},{"channel_1":"off"}]
}

写设备

使用“write”命令以单播方式发送给网关的UDP 9898端口。当用户需要控制各设备时,可使用“write”命令。

例如:

将墙壁开关(单火单键)的状态改为关闭:

{
"cmd":"write",
"model":"ctrl_neutral1",
"sid":"xxxxxxxx",
"key":"3EB43E37C20AFF4C5872CC0D04D81314",
"params":[{"channel_0":"off"}]
}

网关以单播方式回复格式:

{
"cmd":"write_rsp",
"model":"ctrl_neutral1",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}]
}

该“write_rsp”只代表网关收到了write命令,params里的属性状态为当前的设备最新状态,不是write之后的最终设备状态。最终的设备状态靠report报文进行上报。

注意:“key”为32个字节长度的字符串。当网关启用了加密模式时,会对该key进行解密并校验,以验证写命令的合法性。该“key”的生成规则是:用户收到心跳“heartbeat”里的16个字节的“token”字符串之后,使用网关的KEY(在APP里获取的随机KEY)对该字符串进行AES-CBC 128加密,生成16个字节的密文后,再转换为32个字节的ASCII码字符串。

例如:米家智能家庭APP中16个字符长度的随机KEY为“0987654321qwerty“,”token”为”1234567890abcdef”,加密后的密文是:0x3E,0xB4,0x3E,0x37,0xC2,0x0A,0xFF,0x4C,0x58,0x72,0xCC,0x0D,0x04,0xD8,0x13,0x14。那么,”key”为:”3EB43E37C20AFF4C5872CC0D04D81314”。

设备上报和控制报文格式

JSON报文的基本格式:

{
"cmd":"write", //命令类型,支持write/read/write_rsp/read_rsp/report/heartbeat
"model":"ctrl_neutral2", //设备类型
"sid":"xxxxxxxx", //设备的did
"params":[{"channel_0":"on"},{"channel_1":"off"}] //params里可以包含同一个设备的多个属性
}

设备属性列表

介绍Aqara产品的设备类型、属性和使用示例。

空调伴侣

(设备类型model:acpartner.v3)

属性 说明
illumination 空调伴侣的光照度,取值范围一般为0~1300;支持report/read。
proto_version 采用的通信协议版本号,如”2.0.1”。
mid 表示music id,即音乐铃声的id。支持write。取值有:08,1013,20~29(上述为系统自带铃声),10000(表示停止播放铃声),>10001(表示用户自定义的铃声)。
join_permission 取值“yes”/”no”,表示是否允许添加子设备。
remove_device 取值为子设备的did(did的16进制形式的字符串),用于删除某个子设备。
on_off_cfg 空调开关状态,取值为off、on、toggle、invalid
mode_cfg 空调模式,取值为heat、cool、auto、dry、wind、circle、invalid
ws_cfg 空调风速,取值为low、middle、high、auto、circle、invalid
swing_cfg 空调扫风,取值为unswing、swing、invalid
temp_cfg 空调温度,值为整形,取值为当前温度,17~30
relay_status 空调继电器控制,取值为off、on、toggle

例如:

属性上报:

{
"cmd":"report",
"model":"acpartner.v3",
"sid":"xxxxxxxx",
"params":["illumination:500,"proto_version":"2.0.0"}]
//光照度为500,通信协议版本为2.0.0。
}

控制:

播放mid为10005的自定义铃声:

{
"cmd":"write",
"model":"acpartner.v3",
"sid":"xxxxxxxx",
"params":[{"mid":10005}]
}

停止播放铃声:

{
"cmd":"write",
"model":"acpartner.v3",
"sid":"xxxxxxxx",
"params":[{"mid":10000}]
}

允许添加子设备:

{
"cmd":"write",
"model":"acpartner.v3",
"sid":"xxxxxxxx",
"params":[{"join_permission":"yes"}]
}

注意:添加子设备须在30s内进行操作:长按子设备重置键3~5秒直到蓝色指示灯连续闪烁后松开,网关提示设备添加成功,即入网成功。不同子设备长按重置键,指示灯可能不一样,请根据实际情况操作。

删除空调伴侣下的某个子设备:

{
"cmd":"write",
"model":"acpartner.v3",
"sid":"xxxxxxxx",
"params":[{"remove_device":"158d0000f12345"}]
}

空调配置:

{
"cmd":"write",
"model":"acpartner.v3",
"sid":"xxxxxxxx",
"params":[{"on_off_cfg":"on"}]
}

智能插座

(设备类型model:plug)

属性 说明
channel_0 on/off(开/关)
load_power 负载功率,单位是瓦(W)
energy_consumed 从产品开始被使用以来累计的负载消耗电量,单位是瓦时(Wh)

例如:

属性上报:

{
"cmd":"report",
"model":"plug",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}] //智能插座状态为“开”
}

控制:

{
"cmd":"write",
"model":"plug",
"sid":"xxxxxxxx",
"params":[{"channel_0":"off"}] //将智能插座状态改为“关”
}

心跳上报(~10分钟每次):

{
"cmd":"heartbeat",
"model":"plug",
"sid":"xxxxxxxx",
"params":[{"load_power":9.57},{”energy_consumed":57}]
//负载功率为9.57W,负载消耗电量为57Wh。
}

墙壁插座

(设备类型model:ctrl_86plug 和 ctrl_86plug.aq1 )

属性 说明
channel_0 on/off/unknown(开/关/未知)
load_power 负载功率,单位是瓦(W)
energy_consumed 从产品开始被使用以来累计的负载消耗电量,单位是瓦时(Wh)

例如:(以model:ctrl_86plug为例)

属性上报:

{
"cmd":"report",
"model":"ctrl_86plug",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}] //墙壁插座状态为“开”
}

控制:

{
"cmd":"write",
"model":"ctrl_86plug",
"sid":"xxxxxxxx",
"params":[{“channel_0”:”off”}] //将墙壁插座状态改为“关”
}

心跳上报(~10分钟每次):

{
"cmd":"heartbeat",
"model":"ctrl_86plug",
"sid":"xxxxxxxx",
"params":[{"load_power":9.57},{"energy_consumed":57}]
//负载功率为9.57W,负载消耗电量为57Wh。
}

墙壁开关(零火单键)

(设备类型model:ctrl_ln1 和 ctrl_ln1.aq1)

属性 说明
channel_0 on/off/unknown(开/关/未知)

例如:(以model:ctrl_ln1为例)

属性上报:

{
"cmd":"report",
"model":"ctrl_ln1",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}] //墙壁开关状态为“开”
}

控制:

{
"cmd":"write",
"model":"ctrl_ln1",
"sid":"xxxxxxxx",
"params":[{"channel_0":"off"}] //将墙壁开关状态改为“关”
}

墙壁开关(零火双键)

(设备类型model:ctrl_ln2)

属性 说明
channel_0 on/off/unknown(开/关/未知)
channel_1 on/off/unknown(开/关/未知)

例如:

属性上报:

{
"cmd":"report",
"model":"ctrl_ln2",
"sid":"xxxxxxxx",
"params":[{"channel_1":"on"}] //墙壁开关2状态为“开”
}

控制:

{
"cmd":"write",
"model":"ctrl_ln2",
"sid":"xxxxxxxx",
"params":[{"channel_1":"off"}] //将墙壁开关2状态改为“关”
}

墙壁开关(单火单键)

(设备类型model:ctrl_neutral1)

属性 说明
channel_0 on/off(开/关)

例如:

属性上报:

{
"cmd":"report",
"model":"ctrl_neutral1",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}] //墙壁开关状态为“开”
}

控制:

{
"cmd":"write",
"model":"ctrl_neutral1",
"sid":"xxxxxxxx",
"params":[{" channel_0":"off"}] //将墙壁开关状态改为“关”
}

墙壁开关(单火双键)

(设备类型model:ctrl_neutral2)

属性 说明
channel_0 on/off(开/关)
channel_1 on/off(开/关)

例如:

属性上报:

{
"cmd":"report",
"model":"ctrl_neutral2",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}] //墙壁开关1状态为“开”
}
{
"cmd":"report",
"model":"ctrl_neutral2",
"sid":"xxxxxxxx",
"params":[{"channel_1":"on"}] //墙壁开关2状态为“开”
}

控制:

{
"cmd":"write",
"model":"ctrl_neutral2",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}] //将墙壁开关1改为“开”
}
{
"cmd":"write",
"model":"ctrl_neutral2",
"sid":"xxxxxxxx",
"params":[{"channel_1":"off"}] //将墙壁开关2改为“关”
}

窗帘电机

(设备类型model:curtain)

属性 说明
curtain_status open/close/stop/auto (开窗帘/关窗帘/停止工作/自动工作)。支持“write”(write之后设备会上报curtain_level),不支持“report”。
curtain_level 取值:0-100表示打开窗帘的百分比;-1或255表示位置未知。支持“write”和“report”。

例如:

属性上报:

{
"cmd":"report",
"model":"curtain",
"sid":"xxxxxxxx",
"params":[{"curtain_level":50}] //窗帘打开50%
}

控制:

{
"cmd":"write",
"model":"curtain",
"sid":"xxxxxxxx",
"params":[{"curtain_status":"open"}] //开窗帘
}
{
"cmd":"write",
"model":"curtain",
"sid":"xxxxxxxx",
"params":[{"curtain_level":25}] //窗帘打开25%
}

上报窗帘打开状态:

{
"cmd":"report",
"model":"curtain",
"sid":"xxxxxxxx",
"params":[{"curtain_level":25}] //上报窗帘已打开25%
}

双路控制器

(设备类型model:lumi.ctrl_dualchn)

属性 说明
channel_0 on/off/toggle(开/关)
channel_1 on/off/toggle(开/关)

例如:

属性上报:

{
"cmd":"report",
"model":"lumi.ctrl_dualchn",
"sid":"xxxxxxxx",
"params":[{"channel_0":"on"}]
}

RGB调光控制器

(设备类型model:dimmer.rgbegl01)

属性 说明
power_status on/off/unknown (开/关/未知)
light_rgb 取值范围为0-0x64FFFFFF,最高字节表示亮度(0 ~ 0x64),其余3个字节表示颜色值RGB
light_level 取值范围为0~100,表示亮度为1% ~ 100%

例如:

属性上报:

{
"cmd":"report",
"model":"dimmer.rgbegl01",
"sid":"xxxxxxxx",
"params":[{"power_status":"on"}]
}

控制:

{
"cmd":"write",
"model":"dimmer.rgbegl01",
"sid":"xxxxxxxx",
"params":[{"light_rgb":845905783}]
}

空调温控器

(设备类型model:ctrl_hvac.aq1/airrtc.tcpecn01)

属性 说明
on_off_cfg “on”/”off”/“toggle”/”circle”/”invalid” (开/关/切换/循环/未定义值)
mode_cfg “heat”/”cool”/”auto”/”dry”/”wind”/”circle”/”invalid” (制热/制冷/自动/干燥/送风/循环/未定义)
ws_cfg “low”/”middle”/”high”/”auto”/”circle”/”invalid” (低速/中速/高速/自动/循环/未定义)
temp_cfg 值为整形,用户设定的、想达到的环境温度,单位℃
env_temp 空调环境温度,单位℃
on_off_status on/off (开/关),只读

例如:

属性上报:

{
"cmd":"report",
"model":"airrtc.tcpecn01",
"sid":"xxxxxxxx",
"params":[{"on_off_status":"on"}]
}

控制:

{
"cmd":"write",
"model":"airrtc.tcpecn01",
"sid":"xxxxxxxx",
"params":[{"temp_cfg":20}]
}

门窗传感器

(设备类型model:sensor_magnet.aq2)

门窗传感器感知窗户或门的打开/关闭状态,每动作一次发送一次report。

属性 说明
window_status open/close/unknown(开/关/未知)
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv。一般情况下,小于2800mv时表示低电量。

例如:

属性上报:

{
"cmd":"report",
"model":"sensor_magnet.aq2",
"sid":"xxxxxxxx",
"params":[{"window_status":"open"}] //窗户被打开
}

心跳上报(~60分钟每次):

{
"cmd":"report",
"model":"sensor_magnet.aq2",
"sid":"xxxxxxxx",
"params":[{"battery_voltage":3000}]
}

人体传感器

(设备类型model:sensor_motion.aq2)

人体传感器探测到有人移动时会立即report信息,同时上报光照度值”lux”和“illumination”。在一直有人移动的情况下,为了省电,人体传感器最快一分钟发送一次report。人体传感器在每个心跳时,也会上报当前的光照度值”lux”。其他情况下,人体传感器不上报光照度值。

属性 说明
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv。一般情况下,小于2800mv时表示低电量。
motion_status 取值:motion表示探测到有人;unknown表示未知
lux 光照度值,取值范围 0 ~ 1200。在检测到有人移动时采集光照度并上报;或者在传感器心跳时上报。
illumination 光照度值,取值范围 0 ~ 1200,只在检测到有人移动时采集光照度并上报。

例如:

属性上报:

{
"cmd":"report",
"model":"sensor_motion.aq2",
"sid":"xxxxxxxx",
"params":[{"motion_status":"motion"}] //检测到有人移动
}

同时上报光照度值:

{
"cmd":"report",
"model":"sensor_motion.aq2",
"sid":"xxxxxxxx",
"params":[{"lux":100},{"illumination":100}]
}

心跳上报(~60分钟每次):

{
"cmd":"report",
"model":"sensor_motion.aq2",
"sid":"xxxxxxxx",
"params":[{"battery_voltage":3000},{"lux":50}]
}

温湿度传感器

(设备类型model:weather)

温湿度传感器检测到温度变化达到0.5度或者湿度变化达到6%时,发送一次report上报,温度或湿度上报时,同时会上报气压值。温湿度传感器在每次心跳时,也会上报当前温度、湿度和气压值。

属性 说明
temperature 温度,数值型,默认的invalid值为10000。
humidity 湿度,数值型,默认的invalid值为0。
pressure 大气气压值,数值型,单位帕Pa,取值范围30000~110000。默认的invalid值为0。
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv。一般情况下,小于2800mv时表示低电量。

例如:

属性上报:

{
"cmd":"report",
"model":"weather",
"sid":"xxxxxxxx",
"params":[{"temperature":2333}] //温度是23.33度
}

心跳上报(~60分钟每次):

{
"cmd":"heartbeat",
"model":"weather",
"sid":"xxxxxxxx",
"params":[{"battery_voltage":3000}, {"temperature":2333},{"humidity":6678},{"pressure":99900}]
//温度为23.33度,湿度为66.78%,大气气压为99.9KPa。
}

水浸传感器

(设备类型model:sensor_wleak.aq1)

属性 说明
wleak_status 取值:normal表示没有报警或者已解除报警;leak表示发生浸水报警。
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv。一般情况下,小于2800mv时表示低电量。

例如:

属性上报:

{
"cmd":"report",
"model":"sensor_wleak.aq1",
"sid":"xxxxxxxx",
"params":[{"wleak_status":"leak"}] //检测到发生浸水报警
}

心跳上报(~60分钟每次):

{
"cmd":"heartbeat",
"model":"sensor_wleak.aq1",
"sid":"xxxxxxxx",
"params":[{"battery_voltage":3000}]
}

无线开关

(设备类型model:sensor_switch.aq2)

无线开关每按一次按键上报一个报文,400ms内按两次上报的报文是双击。

属性 说明
button_0 click/double_click(单击/双击)
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv。一般情况下,小于2800mv时表示低电量。

例如:

属性上报:

{
"cmd":"report",
"model":"sensor_switch.aq2",
"sid":"xxxxxxxx",
"params":[{"button_0":"click"}]
}

心跳上报(~60分钟每次):

{
"cmd":"heartbeat",
"model":"sensor_switch.aq2",
"sid":"xxxxxxxx",
"params":[{"battery_voltage":3000}]
}

无线开关(升级版)

(设备类型model:sensor_switch.aq3)

无线开关每按一次按键上报一个报文,400ms内按两次上报的报文是双击。

属性 说明
button_0 click/double_click/shake(单击/双击/摇一摇)
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv。一般情况下,小于2800mv时表示低电量。

例如:

属性上报:

{
"cmd":"report",
"model":"sensor_switch.aq3",
"sid":"xxxxxxxx",
"params":[{"button_0":"click"}] //单击无线开关
}

心跳上报(~60分钟每次):

{
"cmd":"heartbeat",
"model":"sensor_switch.aq3",
"sid":"xxxxxxxx",
"params":[{"battery_voltage":3000}]
}

86无线开关单键

(设备类型model:sensor_86sw1.aq1)

属性 说明
button_0 click/double_click(单击/双击)
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv。一般情况下,小于2800mv时表示低电量。

例如:

属性上报:

{
"cmd":"report",
"model":"sensor_86sw1.aq1",
"sid":"xxxxxxxx",
"params":[{"button_0":"double_click"}]
}

86无线开关双键

(设备类型model:sensor_86sw2.aq1)

属性 说明
button_0 click(左键单击);double_click(左键双击)
button_1 click(右键单击);double_click(右键双击)
dual_channel both_click(左右键同时按)

例如:

属性上报:

{
"cmd":"report",
"model":"sensor_86sw2.aq1",
"sid":"xxxxxxxx",
"params":[{"button_1":"double_click"}]
}

魔方传感器

(设备类型model:sensor_cube.aqgl01)

属性 说明
cube_status flip90/flip180/move/tap_twice/shake_air/swing/alert/free_fall/rotate(翻转90度/翻转180度/平移/双击/摇一摇/用力甩/静止一段时间后被触动/自由下落)
rotate_degree 旋转的角度,单位是度(°) ,取值为正数,表示是顺时针转,负数为逆时针转。
detect_time 旋转采样的时间长度,单位毫秒(ms)
battery_voltage 纽扣式电池电压值,单位mv,范围0~3300mv,一般情况下,小于2800mv时表示低电量。

例如:

属性上报:

旋转上报:花了500毫秒逆时针旋转了90度

{
"cmd":"report",
"model":"sensor_cube.aqgl01",
"sid":"xxxxxxxx",
"params":[{“cube_status”:”rotate”},{"rotate_degree":-90},{"detect_time ":500}]
}

其他动作上报:

{
"cmd":"report",
"model":"sensor_cube.aqgl01",
"sid":"xxxxxxxx",
"params":[{"cube_status":"flip90"}]
}

网关局域网通信协议V2.0的更多相关文章

  1. BurpSuite pro v2.0 使用入门教程

    BurpSuite简介 BurpSuite是进行Web应用安全测试集成平台.它将各种安全工具无缝地融合在一起,以支持整个测试过程中,从最初的映射和应用程序的攻击面分析,到发现和利用安全漏洞.Burps ...

  2. [Android]Android端ORM框架——RapidORM(v2.0)

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5626716.html [Android]Android端ORM ...

  3. JuCheap V2.0响应式后台管理系统模板正式发布beta版本

    JuCheap V1.* 查看地址: http://blog.csdn.net/allenwdj/article/details/49155339 经过半年的努力,JuCheap后台通用响应式管理后台 ...

  4. python gettitle v2.0

    #!/usr/bin/env python # coding=utf-8 import threading import requests import Queue import sys import ...

  5. ".NET Compact Framework v2.0 could not be found."

    参考: http://blog.csdn.net/godcyx/article/details/7348431 问题原因: That's a known issue where VS can't di ...

  6. 【JS】heatmap.js v1.0 到 v2.0,详细总结一下:)

    前段时间,项目要开发热力图插件,研究了heatmap.js,打算好好总结一下. 本文主要有以下几部分内容: 部分源码理解 如何迁移到v2.0 v2.0官方文档译文 关于heatmap.js介绍,请看这 ...

  7. 怎样在IDEA中使用JUnit4和JUnitGenerator V2.0自动生成测试模块

     因为项目的需要,所以研究了一下自动生成测试代码.将经验记录下来,总会有用的.我个人认为,好记性不如多做笔记多反思总结. 1.    前提条件 开发环境已正确配置 工程已解决JUnit依赖关系(pom ...

  8. 微信快速开发框架(六)-- 微信快速开发框架(WXPP QuickFramework)V2.0版本上线--源码已更新至github

    4月28日,已增加多媒体上传及下载API,对应MediaUploadRequest和MediaGetRequest ------------------------------------------ ...

  9. 【原创】风讯DotNetCMS V1.0~V2.0 SQL注入漏洞

      文章作者:rebeyond 注:文章首发I.S.T.O信息安全团队,后由原创作者友情提交到乌云-漏洞报告平台.I.S.T.O版权所有,转载需注明作者. 受影响版本:貌似都受影响. 漏洞文件:use ...

随机推荐

  1. Git 版本控制管理(二)

    Git 分支管理 1. 概念 我们来抽象的理解,分支就是科幻电影里面的平行宇宙,当你正在电脑前努力学习Git的时候,另一个你正在另一个平行宇宙里努力学习SVN.如果两个平行宇宙互不干扰,那对现在的你也 ...

  2. ftp服务及其实现之vsftpd

    本文最早发布于我的51CTO博客,目前已迁移至博客园. 简介 FTP,File Transfer Protocol,文件传输协议 文件服务器,具备存储和共享文件(权限设置合理的情况下)的功能 命令端口 ...

  3. 公钥,密钥,HTTPS详解

    公钥与私钥,HTTPS详解 1.公钥与私钥原理1)鲍勃有两把钥匙,一把是公钥,另一把是私钥2)鲍勃把公钥送给他的朋友们----帕蒂.道格.苏珊----每人一把.3)苏珊要给鲍勃写一封保密的信.她写完后 ...

  4. 运维服务器手段(监控宝,Nagios,百度通告平台)

    站在"巨人"的肩膀上运维 现实问题 之前在论坛看到一个运维工程师的帖子,内容如下: "现在的一个IT工作者最头疼的就是加班,秃顶的是IT工作者最多.单身的是IT工作者最多 ...

  5. 概率dp总结

    终于做到概率dp题了,开个总结帖记录一下 首先是几篇论文:有关概率和期望问题的研究 做了这么多题,实际上没什么特别好总结的,就是搞清状态和转移,顺着写就行了,和基本dp差不多 概率是由过去到现在dp[ ...

  6. Codeforces Round #374 (Div. 2) A. One-dimensional Japanese Crosswor 水题

    A. One-dimensional Japanese Crossword 题目连接: http://codeforces.com/contest/721/problem/A Description ...

  7. 将Azure WebSite(应用)集成到虚拟网络

    用过Azure的同学都知道如何将虚拟机加入虚拟网络,也非常简单,但是对于将应用(WebSite)集成到虚拟网络中却很少听到.今天我要讲的就是如何直接将我们部署在WebSite中的应用加入到虚拟网络. ...

  8. 您该选择PRINCE2 还是 PMP认证

    您该选择PRINCE2 还是 PMP认证? 很多人都问我,这是一个非常常见的问题,作为一个项目经理,他们是否应选择PRINCE2或PMP认证,因为这两个认证都是全世界非常流行的. PRINCE2 是一 ...

  9. Serial Wire Viewer (SWV)

    Being able to display values for counters, sensors and other debugging information is an important p ...

  10. 【Go入门教程2】基本构成元素:标识符(identifier)、关键字(keyword 25个)、字面量(literal)、分隔符(delimiter)、和 操作符(operator)

    基本构成要素 Go 的语言符号 又称 词法元素,共包括 5 类内容——标识符(identifier).关键字(keyword).字面量(literal).分隔符(delimiter) 和 操作符(op ...