亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MQTT X v1.4.2新增了哪些功能

發布時間:2021-12-06 16:49:04 來源:億速云 閱讀:139 作者:iii 欄目:互聯網科技

這篇文章主要介紹“MQTT X v1.4.2新增了哪些功能”,在日常操作中,相信很多人在MQTT X v1.4.2新增了哪些功能問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”MQTT X v1.4.2新增了哪些功能”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

腳本功能

MQTT X 在 v1.4.2 版本后,加入了腳本功能,提供了讓用戶編輯腳本對 MQTT 連接中,發送和接收的 Payload 進行自定義轉化的功能。可用來模擬自定義測試場。主要編寫的腳本語言為 JavaScript。下文將簡單的介紹兩個簡單的測試實例場景來對腳本功能進行介紹,需注意:在 v1.4.2 版本中腳本功能屬于開放性測試功能,使用流程、安全性和功能性還需后續繼續優化提升和完善。 也歡迎各位用戶到 MQTT X 的 GitHub issue 區進行詳細討論,我們將會認真審閱和回復。

在編輯腳本功能中,全局只包含了一個 execute API,用戶需要編寫一個自定義函數,該函數接收一個 value 參數,即為 Payload, 函數中便可對 value 進行自定義修改轉化,最后將該函數作為參數傳入到 execute 中即可執行自定義編寫的函數。

實例一

配合定時發送功能模擬溫濕度數據上報。

例如,當用戶使用 EMQ X 時,需要使用規則引擎功能將數據保存到數據庫。這時可以在配置完成后,使用 MQTT X 連接到 EMQ X,并使用腳本功能對其進行測試。這里假設用戶需要保存上報的溫濕度數據,且數據格式為 JSON 類型,我們可以使用下面的腳本對數據進行模擬。

/**
 * Simulated temperature and humidity reporting
 * @return Return a simulated temperature and humidity JSON data - { "temperature": 23, "humidity": 40 }
 * @param value, MQTT Payload - {}
 */

function random(min, max) {
  return Math.round(Math.random() * (max - min)) + min
}

function handlePayload(value) {
  let _value = value
  if (typeof value === 'string') {
    _value = JSON.parse(value)
  }
  _value.temperature = random(10, 30)
  _value.humidity = random(20, 40)
  return JSON.stringify(_value, null, 2)
}

execute(handlePayload)

此時可將這段代碼復制到腳本頁面的代碼編輯框內,點擊右上角的 保存 按鈕,設置腳本名稱為 TempAndHum 并保存。我們在 Input 輸入框內輸入一個 {} 作為初始數據。點擊 測試 按鈕,在 Output 框內查看執行結果,如果結果符合預期,接下來將可以正常使用該腳本。

MQTT X v1.4.2新增了哪些功能

我們使用 EMQ X 提供的 免費公共 MQTT 服務器 新建一個連接,該服務基于 EMQ X 的 MQTT 物聯網云平臺 創建。服務器接入信息如下:

  • Broker: broker.emqx.io

  • TCP Port: 1883

  • Websocket Port: 8083

連接成功后,點擊右上角的下拉功能菜單,選擇 使用腳本,在彈出窗中,選擇剛才保存好的 TempAndHum 腳本,然后選擇應用類型為發送時,點擊確認按鈕后開啟腳本功能。

MQTT X v1.4.2新增了哪些功能

開啟腳本后,我們再繼續設置定時發送功能,同樣點擊右上角的下拉功能菜單,選擇 定時消息,這里我們設置發送頻率為 1 秒,點擊確認后定時消息功能開啟。

MQTT X v1.4.2新增了哪些功能

準備好后,便可以輸入初始的 Payload 和需要發送到的Topic,點擊發送成功一條消息后,便可以看到 MQTT X 將每秒自動發送了一次模擬數據。

MQTT X v1.4.2新增了哪些功能

這樣避免了用戶去手動輸入和修改數據的麻煩,且使用腳本時模擬數據可控,模擬數據區間可在腳本的 random 函數中設定,如果有對保存的數據進行可視化圖表測試需求或需要添加一定的數據量的數據來測試時,都較為方便和友好。

實例二

將接收到的 Payload 中的時間戳轉化為正常時間。

在一些測試場景中,用戶測試接收到的 Payload 內可能會包含時間戳信息,如果需要觀察和測試對時間較為敏感的數據,可能需要復制出數據,再將時間戳轉化時間,較為麻煩。此時可以使用腳本對接收到的數據進行自動轉化,方便用戶觀察數據信息。我們可以使用下面的腳本對數據進行轉化。依然假設接收到的數據為 JSON 類型,并且包含了 time 字段。

/**
 * Convert timestamp to normal time.
 * @return Return the UTC time - { "time": "2020-12-17 14:18:07" }
 * @param value, MQTT Payload - { "time": 1608185887 }
 */

function handleTimestamp(value) {
  let _value = value
  if (typeof value === 'string') {
    _value = JSON.parse(value)
  }
  // East Eight District needs an additional 8 hours
  const date = new Date(_value.time * 1000 + 8 * 3600 * 1000)
  _value.time = date.toJSON().substr(0, 19).replace('T', ' ')
  return JSON.stringify(_value, null, 2)
}

execute(handleTimestamp)

此時可將這段代碼復制到腳本頁面的代碼編輯框內,點擊右上角的 保存 按鈕,設置腳本名稱為 Time 并保存。我們在 Input 輸入框內輸入一個 { "time": 1608365158 } 作為初始數據。點擊 測試 按鈕,在 Output 框內查看執行結果,如果結果符合預期,接下來將可以正常使用該腳本。

MQTT X v1.4.2新增了哪些功能

此時我們依然新建一個連接,使用上述中描述的方法來開啟腳本。注意選擇應用類型時,需要選擇為接收時。

MQTT X v1.4.2新增了哪些功能

腳本功能開啟后,我們添加一個 testtopic/timeTopic,然后我們向該 Topic 發送一條包含時間戳信息的 Payload。然后查看接收到的 Payload 信息,可以看到已經自動幫時間戳轉化為了正常時間。

MQTT X v1.4.2新增了哪些功能

到此,關于“MQTT X v1.4.2新增了哪些功能”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

衢州市| 曲周县| 白城市| 白玉县| 霍城县| 荥经县| 揭东县| 桓台县| 乐清市| 台北县| 陕西省| 宁乡县| 安图县| 丰都县| 舒城县| 周至县| 柳林县| 贡嘎县| 静安区| 治县。| 琼海市| 青河县| 裕民县| 乐亭县| 庆安县| 永丰县| 蓬溪县| 民权县| 泸水县| 日土县| 郴州市| 罗山县| 紫金县| 柘城县| 延吉市| 霍林郭勒市| 罗田县| 济阳县| 徐水县| 松滋市| 游戏|