基於華為物聯網IOT的應用開發 ---界面管理開發

来源:https://www.cnblogs.com/wuhuacong/archive/2019/11/11/11833440.html
-Advertisement-
Play Games

在前面隨筆《基於華為物聯網IOT的應用開發 --- 基於.net 的SDK封裝》介紹過IOT中應用側SDK的封裝,主要就是基於華為IOT的應用側封裝,以便在應用系統中進行調用。應用側SDK的封裝是一切應用開發的基礎,不過華為並沒有提供對應.net的SDK封裝,不過SDK都是基於Web API 的J... ...


在前面隨筆《基於華為物聯網IOT的應用開發 --- 基於.net 的SDK封裝》介紹過IOT中應用側SDK的封裝,主要就是基於華為IOT的應用側封裝,以便在應用系統中進行調用。應用側SDK的封裝是一切應用開發的基礎,不過華為並沒有提供對應.net的SDK封裝,不過SDK都是基於Web  API 的JSON數據進行交互,因此花了一點時間進行了華為.net 的SDK進行了全面封裝,本篇隨筆介紹如何基於封裝好的IOT 應用側的SDK進行界面管理的開發,實現對IOT業務數據的管理等。

1、應用側SDK封裝回顧

應用側的開發介面一般雲平臺都會提供不同平臺的SDK,如阿裡雲開源提供Java SDK/C# SDK等;而華為則提供了Java、PHP等SDK,沒有包含.net 的SDK。華為物聯網雲的應用側API介面包括:

 

基於對應應用側API介面的定義,我們使用C#進行了對應介面的封裝。

  包含了一個測試介面項目、一個SDK封裝介面項目,以及一個訂閱的消息推送介面的解析和處理,例如新增設備、設備信息變化、設備綁定激活等。

對於事件的通知,我們一般是在應用端被動的進行相應的處理,因此需要對它們的消息進行轉換和處理。

類似在管理後臺訂閱這些事件,然後這些事件觸發後會推送給應用伺服器。

  

2、介面的測試使用

根據IOT的應用側API的定義,我們編寫一個快速測試SDK工作情況的Winform程式來測試,如獲取授權信息,以及查詢產品、註冊設備、修改設備、獲取設備狀態和詳細等等介面的正常與否,然後再在Web應用中進行整合,這樣可以減少返工調試的問題。

按照業務介面的歸類測試,我們編寫如下程式用來測試對應SDK介面。

 在使用SDK介面前,我們需要知道,華為IOT的API介面,基本上全部需要證書的對接的,這個和我們開發微信API有所差異。例如,我們的Winform測試程式,讓它帶有一個Cert目錄下的證書文件,這個證書文件可以在API的Demo裡面找到,或者在華為IOT平臺上下載。

 我們最終用到的是cert/outgoing.CertwithKey.pkcs12這個證書文件。

 我們創建一個HTTPRequest對象獲取數據的時候,需要指定這個證書,如下所示。

helper.ContentType = "application/json";
helper.ClientCertificates = new X509CertificateCollection() { new X509Certificate2(Constants.CertFilePath, Constants.CertPassword) };

其他部分就是對API介面封裝的調用測試了。

如首先是授權的測試,用來獲取AccessToken的,這個是調用其他介面的前提。

private void btnLogin_Click(object sender, EventArgs e)
{
    var result = basicApi.Authentication();
    Console.WriteLine(result != null ? "accessToken:" + result.ToJson() : "獲取結果出錯");

    if (result != null)
    {
        var refreshResult = basicApi.RefreshToken(result.refreshToken);

        Console.WriteLine(refreshResult != null ? "accessToken:" + refreshResult.ToJson() : "獲取結果出錯");
        this.accessToken = refreshResult.accessToken;//記錄待用
    }
}

華為IOT介面很多沒有全部整合在一起,有的在https://support.huaweicloud.com/api-IoT/iot_06_0003.html ,而有的則在https://support.huaweicloud.com/api-iothub/iot_06_0008.html, 就拿授權來說,還有另外一個版本的介面可以獲取,兩個介面獲得的token都可以通用。

var url = Constants.AppBaseUrl + "/iocm/app/sec/v1.1.0/login";
var url = Constants.AppBaseUrl + "/api/v3.0/auth/tokens";

這兩個地址都可以獲取AccessToken,如設備創建,也是有多個介面,版本不同。

我們針對各個介面的封裝,對相關介面進行測試,如基於產品、產品下麵的列表等信息,可以在一個介面測試代碼裡面進行測試,如下所示。

        /// <summary>
        /// 產品相關介面測試
        /// </summary>
        private void btnProduct_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrEmpty(accessToken))
            {
                MessageUtil.ShowTips("請先鑒權獲取AccessToken");
                return;
            }
            try
            {
                var productApi = new ProductApi();
                var deviceApi = new DataCollectionApi();

                //查詢產品列表
                var queryJson = new QueryProductJson { ownerAppId = Constants.AppId };
                var result = productApi.QueryProduct(accessToken, queryJson);
                Console.WriteLine(result != null ? result.ToJson() : "no result");

                if (result != null && result.products != null)
                {
                    //遍歷產品,根據產品ID獲取產品信息
                    foreach (var p in result.products)
                    {
                        var detailResult = productApi.QueryProduct(accessToken, p.productId, Constants.AppId);
                        Console.WriteLine(detailResult != null ? detailResult.ToJson() : "no result");
                    }

                    //遍歷產品下麵的設備信息
                    foreach (var p in result.products)
                    {
                        var deviceJson = new QueryDeviceJson { ownerAppId = Constants.AppId, productId = p.productId };
                        var deviceResult = deviceApi.BatchQueryDevice2(accessToken, deviceJson);
                        Console.WriteLine(deviceResult != null ? deviceResult.ToJson() : "no result");
                    }
                }
            }
            catch (Exception ex)
            {
                MessageUtil.ShowError(ex.Message);
            }
        }

對於設備,產品、設備組,都屬於設備的入口之一,因此設備組也是管理介面設備的一個類別,我們可以根據SDK對設備組介面進行測試,如下代碼所示。

        /// <summary>
        /// 設備分組測試
        /// </summary>
        private void btnDeviceGroup_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrEmpty(accessToken))
            {
                MessageUtil.ShowTips("請先鑒權獲取AccessToken");
                return;
            }

            try
            {
                //根據自己數據修改
                var deviceId = "64bf5869-b271-4007-8db8-fab185e19c10";
                var groupName = "testGroup";
                var groupApi = new DeviceGroupApi();
                var groupJson = new CreateDeviceGroupJson()
                {
                    appId = Constants.AppId,
                    name = groupName,
                    description = "測試設備分組",
                    deviceIds = { deviceId }
                };

                //創建設備組
                var result = groupApi.CreateDeviceGroup(accessToken, groupJson);
                Console.WriteLine(result != null ? result.ToJson() : "no result");

                //查詢設備組
                var queryJson = new QueryDeviceGroupJson()
                {
                    accessAppId = Constants.AppId,
                    name = groupName
                };
                var queryResult = groupApi.QueryDeviceGroup(accessToken, queryJson);
                Console.WriteLine(queryResult != null ? queryResult.ToJson() : "no result");

                //查詢設備組成員
                if (queryResult != null && queryResult.list != null)
                {
                    foreach (var group in queryResult.list)
                    {
                        //設備明細
                        var groupResult = groupApi.GetDeviceGroup(accessToken, group.id, Constants.AppId);
                        Console.WriteLine(groupResult != null ? groupResult.ToJson() : "no result");

                        //設備組成員
                        var queryMemberJson = new QueryDeviceGroupMemberJson()
                        {
                            appId = Constants.AppId,
                            devGroupId = group.id
                        };
                        var queryMemberResult = groupApi.QueryDeviceGroupMember(accessToken, queryMemberJson);
                        Console.WriteLine(queryMemberResult != null ? queryMemberResult.ToJson() : "no result");
                    }
                }
            }
            catch (Exception ex)
            {
                MessageUtil.ShowError(ex.Message);
            }
        }

 

3、IOT業務界面管理開發

當我們把大多數介面都跑一遍,並解決相關問題後,我們就可以根據這些介面進行Web應用的開發了。

為了方便,我們把IOT相關的業務,定義在一個控制器裡面,方便管理,以後如果有需要,可以拆分進行管理。

 例如,對於數據提供,主要就是分頁JSON數據的處理,方便界面控制項通過Ajax進行獲取數據顯示。

例如,對於產品列表,我們構建了一個控制器方法,如下所示。

        /// <summary>
        /// 根據條件查詢產品列表,並返回對象集合(用於分頁數據顯示)
        /// </summary>
        /// <returns>指定對象的集合</returns>
        public virtual ActionResult FindProductWithPager()
        {
            var pagerInfo = GetPagerInfo();
            var sort = GetSortOrder();
            var accessToken = GetAccessToken();

            var queryJson = new QueryProductJson(pagerInfo) { ownerAppId = Constants.AppId };
            var result = productApi.QueryProduct(accessToken, queryJson);

            var list = result != null ? result.products : null;
            var totalCount = result != null ? result.totalCount : 0;

            //Json格式的要求{total:22,rows:{}}
            var jsonResult = new { total = totalCount, rows = list };
            return ToJsonContent(jsonResult);
        }

其他,如設備組、設備列表等類似的處理,都是先通過介面獲取數據,然後組裝為對應的JSON格式提供給視圖即可。

 有時候,除了列表展示外,我們可能還需要對視圖中創建、刪除、獲取單個明細的介面進行處理,如下所示是設備分組的管理介面。

 其他的業務對象也是類似的封裝,有了這些介面,我們就可以處理分頁、獲取詳細、編輯、刪除等介面的處理了。

在Web應用中定義幾個業務菜單,用來管理產品信息、設備組和設備信息。

  產品管理界面如下所示。

如果我們要查看產品明細,調用對應介面進行展示即可。

包含設備列表,我們根據產品ID獲取對應設備列表返回到界面進行展示即可,如下所示效果。

 設備分組如下所示。

 而設備列表展示可以通過產品和設備組進行限定查詢,我們如下管理這個設備列表的展示的。

 同樣,設備詳細信息,通過對應ID調用SDK介面獲取數據,並返回到視圖即可展示出來了。設備的相關信息,如下歷史數據、歷史命令等,我們也可以通過對應介面進行數據獲取返回,在界面的Tab控制項進行展示即可。

 如設備歷史命令,可以獲取到相關歷史命令信息。

 以上就是對IOT應用側API介面的封裝和應用界面的管理開發,不過使用過程中,對於IOT的介面還是不夠完善,希望華為在這方便能夠繼續完善和提供良好的開發人員支持,我們也繼續關註,以便在後續項目中整合物聯網的硬體設備進行使用。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • using System; namespace test { class Program { static void Main(string[] args) { Cat kitty = new Cat(); // 無參構造函數 Cat1 KITTY = new Cat1("KITTY", 4); C ...
  • IIS文件上傳大小限制30M,C盤中有的IIS_schema.xml文件 C:\Windows\System32\inetsrv\config\schema\ 但是考慮到安全等問題,而且這個文件預設是只讀的,所以不建議直接修改這個配置文件,而應該在iis的管理器里修改: 一、打開某一個網站或者點擊根 ...
  • 基本數據類型 C 支持完整的BCL(基類庫)名字,但是最好都統一使用關鍵字進行使用與開發,比如使用int而不是System.Int32,以及使用string類型時候應當使用string而不是Systen.String以及String。 作為一名擁有良好編寫習慣的程式員,要一致!不要變來變去! 整數類 ...
  • 前言:作為一個程式員你要學會調試,對於一種調試都無法找到問題所在的情況,你要學會看日誌,要學會看日誌你的學會怎麼樣去寫入日誌,接下來教你配置C#Log4 第一步,你的在配置文件中配置好對應的參數 <!--配置log4--> <configSections> <section name="log4ne ...
  • PDF是當今最流行的文檔格式之一,各種應用程式將其用作最終輸出。由於支持多種數據類型和可移植性,因此它是創建和共用內容的首選格式。作為對開發文檔管理應用程式感興趣的.NET應用程式開發人員,可能希望嵌入處理功能,以讀取PDF文檔並將其轉換為其他文件格式,例如HTML。 Aspose.PDF for ...
  • 又到了每月新版更新時間!Aspose.PDF for .NET升級到v19.11版,在擴展中添加為HTML頁面設置leftMargin和rightMargin的功能,同時支持居中對齊輸出HTML,我們一起來看看有哪些新功能吧! Aspose.PDF for .NET是一種高級PDF處理和解析API, ...
  • static void MutexDemo2() { string assName = Assembly.GetEntryAssembly().FullName; bool createdNew; using (var mutex = new Mutex(false, assName, out cr... ...
  • AspectCore是適用於Asp.Net Core 平臺的輕量級Aop(Aspect oriented programming)解決方案,它更好的遵循Asp.Net Core的模塊化開發理念,使用AspectCore可以更容易構建低耦合、易擴展的Web應用程式。 在使用過程中,由於相關文檔、博客還 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...