全部產品
Search
文件中心

IoT Platform:編寫自訂指令碼

更新時間:Jun 30, 2024

資料解析任務中源節點的Topic資料格式為未經處理資料時,可以使用自訂指令碼進行解析。物聯網平台支援配置JavaScript(ECMAScript 5)、Python 2.7和PHP 7.2語言的指令碼。本文介紹自訂Topic資料解析指令碼模板和樣本。

JavaScript指令碼樣本

指令碼模板

/**
 * 將裝置自訂Topic資料轉換為JSON格式資料,裝置上報資料到物聯網平台時調用。
 * 入參:data,byte[]數組,不可為空。
 * 出參:jsonObj,對象,不可為空。
 */
function executeScript(data) {
    var jsonObj = {};
    return jsonObj;
}

指令碼樣本

/*
  樣本資料:
  自訂Topic:
     /user/update,上報資料。
  輸入參數:
     data: 0x000000000100320100000000
  輸出參數:
    {
        "prop_float": 0,
        "prop_int16": 50,
        "prop_bool": 1
    }
 */
function executeScript(data) {
    var uint8Array = new Uint8Array(data.length);
    for (var i = 0; i < data.length; i++) {
        uint8Array[i] = data[i] & 0xff;
    }
    var dataView = new DataView(uint8Array.buffer, 0);
    var jsonMap = {};
    jsonMap['prop_int16'] = dataView.getInt16(5);
    jsonMap['prop_bool'] = uint8Array[7];
    jsonMap['prop_float'] = dataView.getFloat32(8);

    return jsonMap;
}

Python指令碼樣本

指令碼模板

# 將裝置自訂Topic資料轉換為JSON格式資料,裝置上報資料到物聯網平台時調用。  
# 入參: data,列表,列表元素取值為int類型,不可為空。
# 出參: jsonObj,字典。    
def execute_script(data):
   jsonObj = {}
   return jsonObj

指令碼樣本

# coding=UTF-8

#  樣本資料:
#  自訂Topic:/user/update,上報資料。
#  輸入參數:
#     data: 0x000000000100320100000000
#  輸出參數:
#  {
#     "prop_float": 0,
#     "prop_int16": 50,
#     "prop_bool": 1
#   }
def execute_script(data):
    uint8Array = []
    for byteValue in data:
        uint8Array.append(byteValue & 0xff)

    jsonMap = {}
    jsonMap['prop_int16'] = bytes_to_int(uint8Array[5:7])
    jsonMap['prop_bool'] = bytes_to_int(uint8Array[7: 8])
    jsonMap['prop_float'] = bytes_to_int(uint8Array[8:])

    return jsonMap

# byte數群組轉換為整型。
def bytes_to_int(bytes):
    data = ['%02X' % i for i in bytes]
    return int(''.join(data), 16)

PHP指令碼樣本

指令碼模板

<?php
/**
 * 將裝置自訂Topic資料轉換為JSON格式資料,裝置上報資料到物聯網平台時調用。
 * 入參:$data,普通數組,數組元素為整數。
 * 出參:$jsonObj,關聯陣列,關聯陣列key取值為英文字串不能是字元的數字如"10",不可為空。
 */
function executeScript($data)
{
    $jsonObj = array();
    return $jsonObj;
}
    重要

    請避免使用全域變數或者static變數,否則會造成執行結果不一致。

    指令碼中,處理資料採用補碼的方式, [-128, 127]補碼範圍為[0, 255]。例如:-1對應的補碼為255(10進位表示)。

    自訂協議解析的函數(executeScript)的入參為整型數組,需要通過0xFF進行與操作,擷取其對應的補碼。返回結果為關聯陣列,要求key取值包含非數組字元(例如:數組key為“10”,PHP數組中會擷取到整數10)。

    PHP執行環境對於異常處理要求嚴格,例如:發生錯誤會直接拋出異常,後續代碼不會執行。為保證代碼的健壯性,對於異常需要捕獲並進行處理。

指令碼樣本

<?php
/*
  樣本資料
  自訂Topic:
     /user/update,上報資料。
  輸入參數:
     data: 0x000000000100320100000000。
  輸出參數:
  {
     "prop_float": 0,
     "prop_int16": 50,
     "prop_bool": 1
   }
 */
function executeScript($bytes)
{
    $data = array();
    $length = count($bytes);
    for ($i = 0; $i < $length; $i++) {
        $data[$i] = $bytes[$i] & 0xff;
    }

    $jsonMap = array();
    $jsonMap['prop_int16'] = getInt16($data, 5);
    $jsonMap['prop_bool'] = $data[7];


    return $jsonMap;
}


function getInt16($bytes, $index)
{
    $array = array($bytes[$index], $bytes[$index + 1]);

    return hexdec(byteArrayToHexString($array));
}

function byteArrayToHexString($data)
{
    $hexStr = '';
    for ($i = 0; $i < count($data); $i++) {
        $hexValue = dechex($data[$i]);

        $tempHexStr = strval($hexValue);

        if (strlen($tempHexStr) === 1) {
            $hexStr = $hexStr . '0' . $tempHexStr;
        } else {
            $hexStr = $hexStr . $tempHexStr;
        }
    }

    return $hexStr;
}

相關文檔

選擇指令碼語言,完成自訂指令碼編輯和調試。具體操作,請參見配置源節點