[小 迪 导读]:在控制设备的过程中,经常会碰到下面这些问题:

老式方案 dgiot基于dlink协议配置同步方案
平台根据实际情况控制开关机 平台远程控制设备同步开关机状态

老式方案缺点:

  • 当平台控制指令没有发下去时,平台需要再次点击发出控制指令,较浪费人力

dgiot配置同步方案优点:

  • 设备上电,设备状态全权由平台管理员控制即平台控制值,例如:平台为关机,现场设备即使开机平台将会自动下发关机指令,将设备再次关机。

整体交互图

方案执行步骤

1.在平台上创建产品,如下图为例。

 title=

2.在产品详情的物模型中创建设备上传的"key":"value"对应的物模型,如下图为例。

 title=

3.在产品详情的可视化中添加低代码,如下图为例。

 title=

4.点击设计编辑低代码,先编辑成产品的低代码用以添加平台的key与上传设备的key进行关联,如下图。



产品低代码例子,以实际产品为准:
{
  "type": "form",
  "api": {
    "url": "iotapi/classes/Device/parse_objectid",
    "method": "put",
    "headers": {
      "store": "localStorage",
      "dgiotReplace": "parse_objectid"
    },
    "dataType": "json",
    "requestAdaptor": "return {\r\n  \"status\":0,\r\n  \"msg\":\"\",\r\n  \"data\":response\r\n  }"
  },
  "body": [
    {
      "id": "u:52fbc3355570",
      "mode": "inline",
      "name": "Ctrl",
      "type": "switch",
      "label": "开关机",
      "onText": "开",
      "option": "",
      "offText": "关",
      "trueValue": 1,
      "falseValue": 0,
      "validateApi": {
        "url": "iotapi/amis/Product/b5f75b59a3",
        "method": "put",
        "requestAdaptor": "return {\r\n  ...api,\r\n  data:{\r\n    profile:{\r\n      Ctrl:api.data.Ctrl    \r\n      }\r\n  }\r\n}"
      },
      "submitOnChange": true
    }
  ],
  "title": "开关机控制器",
  "trueValue": true,
  "falseValue": false,
  "submitText": "",
  "optionAtLeft": false
}

5.在产品详情的可视化中找到刚刚创建的低代码,点击预览,点击一下开关机添加平台key,如下图。

<img src="http://dgiot-1253666439.cos.ap-shanghai-fsi.myqcloud.com/dgiot_web/doc_ylb/equipment_operational/7.png" width="100%">

6.在产品详情的物模型中找到刚刚创建的物模型,点击编辑,关联平台key与设备key,如下图。

<img src="http://dgiot-1253666439.cos.ap-shanghai-fsi.myqcloud.com/dgiot_web/doc_ylb/equipment_operational/8.png" width="100%">

7.在产品详情的可视化中找到刚刚创建的低代码,点击设计,修改为设备的低代码,如下图。

 title=

设备低代码示例:
{
  "type": "form",
  "api": {
    "url": "iotapi/classes/Device/parse_objectid",
    "method": "put",
    "headers": {
      "store": "localStorage",
      "dgiotReplace": "parse_objectid"
    },
    "dataType": "json",
    "requestAdaptor": "return {\r\n  \"status\":0,\r\n  \"msg\":\"\",\r\n  \"data\":response\r\n  }"
  },
  "body": [
    {
      "id": "u:52fbc3355570",
      "mode": "inline",
      "name": "Ctrl",
      "type": "switch",
      "label": "开关机",
      "onText": "开",
      "option": "",
      "offText": "关",
      "trueValue": 1,
      "falseValue": 0,
      "validateApi": {
        "url": "iotapi/amis/Device/parse_objectid",
        "method": "put",
        "headers": {
          "store": "localStorage",
          "dgiotReplace": "parse_objectid"
        },
        "requestAdaptor": "return {\r\n  ...api,\r\n  data:{\r\n    profile:{\r\n      Ctrl:api.data.Ctrl    \r\n      }\r\n  }\r\n}"
      },
      "submitOnChange": true
    }
  ],
  "title": "开关机控制器",
  "trueValue": true,
  "falseValue": false,
  "submitText": "",
  "optionAtLeft": false
}

8.设备模拟登录,方式一:MQTTX登录;方式二:ip:18083登录,用户名:admin,密码:public

方式一:MQTTX登录

 title=

方式二:ip:18083登录,用户名:admin,密码:public

 title=
用户名及密码获取方式,如下图:
 title=

9.设备数据模拟上报,方式一:MQTTX上报;方式二:ip:18083上报

dgiot上报数据Topic
    $dg/thing/{ProductId}/{DeviceAddr}/properties/report
dgiot下发控制命令Topic
    $dg/device/{ProductId}/{DeviceAddr}/profile

可以在设备详情查看其对应Topic,如下图:
 title=
 title=

方式一:MQTTX上报

 title=

上报数据

 title=

订阅到的控制指令

 title=

方式二:ip:18083上报

 title=

上报数据

 title=

订阅到的控制指令

 title=

10.设备配置同步实现,以ip:18083为例

平台设置为开机,如下图

 title=

ip:18083模拟上报状态值为0(关机的状态),平台自动下发开机命令,如下图

 title=

平台设置为关机,如下图

 title=

ip:18083模拟上报状态值为1(开机的状态),平台自动下发关机命令,如下图

 title=

[小 迪 点评]

  • dgiot平台配置同步下发控制指令。
  • 在成本方面dgiot为降低用户使用成本,降低运维成本。

想了解更多 dgiot 的具体细节,欢迎大家在GitHub上查看相关源代码。


DGIoT
1 声望3 粉丝