本文由企鵝圈原創成員Hunter_Zhu貢獻。ios
本篇文章是基於近期一個項目微信端開發過程的一個總結。文中主要介紹了雲智易平臺下微信端開發的流程、該平臺提供的主要功能以及這次H5開發使用到的一些UI組件。可以幫助企鵝仔高速對該平臺微信開發有個瞭解。web
本文介紹的微信硬件物聯網開發思路不侷限於某個平臺。對市場上所有的平臺,如機智雲也是適用的,特此說明。數據庫
1、建立微信應用,配置微信server編程
在雲智易開發平臺中,開發人員需要在應用管理中建立一個微信應用,填寫微信公衆號的基本信息:APPID, APPSecret等,另外平臺會爲該應用生成一對APPUrl以及APPToken可用於配置微信公衆平臺設備功能的server配置。假設開發人員採用這樣的方式,那麼微信server轉發的設備事件(如綁定/解綁/訂閱設備狀態等)都由雲智易平臺處理。微信
固然。開發人員也可以採用第二種方式。即自身先處理微信硬件的設備事件。並轉發設備事件通知雲智易平臺。websocket
在微信硬件平臺中建立了產品後。咱們就可以方便地在雲智易平臺中指定受權的微信產品號批量完畢設備微信受權,獲取設備的二維碼連接。微信開發
在此部分中主要體現物聯網中用戶管理、設備管理、用戶和設備綁定的情景。微信公衆平臺
2、微信設備控制socket
在雲智易平臺中,微信H5和server採用websocket進行通訊。post
上圖是雲智易平臺提供的微信應用開發流程圖,從圖中可以看出,微信設備開發可分5步走:
1)經過OAuth2.0獲取微信用戶的openid。
2)以openid爲參數獲取微信用戶的認證碼用於初始化XSDK實例;
3)以openid爲參數獲取微信用戶的設備列表;
4)向XSDK實例導入設備列表;
5)經過XSDK實例監聽設備的上報數據/向設備下發數據/監聽設備的在離線狀態變化/主動讀取設備數據等。
上圖中經過調用雲智易平臺提供的xsdk.js文件就能夠完畢物聯網的基本需求:用戶和設備通訊(讀、寫、訂閱和通知),另外的功能拓展雲智易平臺經過RESTful接口想開發人員進行提供。針對微信開發除了上述中獲取用戶綁定的設備列表接口外還包含:
1)取消綁定設備;
2)獲取微信JSAPI調用簽名;
3)獲取設備的信息。
4)改動設備的名稱;
5)獲取微信用戶在雲智易平臺下的接口調用憑證access-token;
雲智易平臺提供了大量的RESTful接口拓展各類情景的功能,大部分都需要上述獲取到的access-token來完畢調用。
3、數據服務
物聯網情景中大多不知足於主要的設備控制,很是多時候需要爲用戶提供歷史數據查看服務。雲智易平臺提供了四大數據服務:數據表,數據快照,統計規則以及數據轉發。
數據表功能類似數據庫,是雲智易爲開發人員提供的數據存儲功能,開發人員經過調用RESTful接口可進行增刪查改操做;
數據快照功能用於存儲設備某一時刻的狀態,經過設備快照服務可以獲取歷史數據以及變化的數據。
統計規則功能是基於數據快照的數據進行統計,獲取數據的特徵,如統計某個時間段內數據的最大值。最小值。平均值等信息;
數據轉發服務可實現設備數據到開發人員server的轉發,如設備上報的數據、設備的在離線狀態變化等。
前面三大數據server都是可以經過RESTful接口來完畢,在數據轉發服務中需要完畢和微信開發中同樣的server驗證,隨後server就可以對轉發過來的數據進行個性存儲處理。
近期一個項目開發中。本人在數據展示上使用的是百度ECharts圖表,ECharts功能強大,在實時數據和歷史數據展示過程當中主要使用了當中的數據區域縮放組件(dataZoom),經過這個組件,咱們可以對大量的數據進行展示,對數據區域進行防縮、平移以關注某一小段的數據。例如如下圖所展現,有了這兩個功能就能實現大量數據的顯示查看。
4、告警功能
雲智易平臺中提供了兩種設備告警的方式,一種是經過微信公衆號直接推送告警,第二種用戶在設備控制頁面可以查看告警的消息。第一種方式是經過設置認證了的微信服務號的模板消息實現的,不需要涉及編程,對於第二種是經過平臺提供的RESTful接口進行獲取,而後再向用戶進行展示。告警功能實現了設備出現異常時對用戶通知的實時性,提示用戶前去查看,告警的內容可以包含:設備某個數值超過指定範圍獲取設備的在離線狀態通知等。
公衆號推送告警信息:
設備控制頁面中獲取告警列表:
5、UI組件
最後,向你們分享一下微信H5開發中一個不錯的UI組件——MUI。其以ios平臺UI爲基礎,追求原生UI感受。例如如下圖的輸入對話框。除此之外。在性能上也有很是好的用戶體驗。
不少其它嵌入式Linux和物聯網原創技術分享敬請關注微信公衆號:嵌入式企鵝圈