使用OpcUaHelper在C# WinForms中連接OPC UA服務器并讀取數據

使用OpcUaHelper在C# WinForms中連接OPC UA服務器并讀取數據

下面是一個完整的示例,展示如何使用OpcUaHelper庫在C# WinForms應用程序中連接OPC UA服務器并讀取數據。

1. 準備工作

首先,確保你已經安裝了OpcUaHelper NuGet包。可以通過NuGet包管理器控制臺安裝:

Install-Package OpcUaHelper

2. 創建WinForms應用程序

2.1 設計界面

創建一個簡單的WinForms窗體,包含以下控件:

  • 文本框:用于輸入服務器URL
  • 連接/斷開按鈕
  • 節點ID文本框
  • 讀取按鈕
  • 數據顯示區域(如DataGridView或ListBox)

2.2 完整代碼示例

using OpcUaHelper;
using System;
using System.Collections.Generic;
using System.Windows.Forms;namespace OpcUaWinFormsClient
{public partial class MainForm : Form{private OpcUaClient opcUaClient = new OpcUaClient();private bool isConnected = false;public MainForm(){InitializeComponent();UpdateUiState();}private void btnConnect_Click(object sender, EventArgs e){if (!isConnected){ConnectToServer();}else{DisconnectFromServer();}}private async void ConnectToServer(){string serverUrl = txtServerUrl.Text.Trim();if (string.IsNullOrEmpty(serverUrl)){MessageBox.Show("請輸入有效的服務器URL");return;}try{btnConnect.Enabled = false;lblStatus.Text = "正在連接...";// 連接到服務器await opcUaClient.ConnectServerAsync(serverUrl);isConnected = true;lblStatus.Text = "已連接";MessageBox.Show("連接成功!");}catch (Exception ex){lblStatus.Text = "連接失敗";MessageBox.Show($"連接失敗: {ex.Message}");}finally{btnConnect.Enabled = true;UpdateUiState();}}private void DisconnectFromServer(){try{opcUaClient.Disconnect();isConnected = false;lblStatus.Text = "已斷開";}catch (Exception ex){MessageBox.Show($"斷開連接時出錯: {ex.Message}");}finally{UpdateUiState();}}private void UpdateUiState(){btnConnect.Text = isConnected ? "斷開連接" : "連接";btnRead.Enabled = isConnected;txtNodeId.Enabled = isConnected;}private async void btnRead_Click(object sender, EventArgs e){string nodeId = txtNodeId.Text.Trim();if (string.IsNullOrEmpty(nodeId)){MessageBox.Show("請輸入節點ID");return;}try{btnRead.Enabled = false;// 讀取單個節點值var value = await opcUaClient.ReadNodeAsync(nodeId);// 顯示讀取結果lstResults.Items.Add($"節點: {nodeId}, 值: {value}, 類型: {value?.GetType()}");lstResults.TopIndex = lstResults.Items.Count - 1;}catch (Exception ex){MessageBox.Show($"讀取數據時出錯: {ex.Message}");}finally{btnRead.Enabled = true;}}private async void btnBrowse_Click(object sender, EventArgs e){try{treeNodes.Nodes.Clear();var rootNode = treeNodes.Nodes.Add("Root");// 瀏覽服務器節點await BrowseNodeAsync("i=84", rootNode); // Objects文件夾通常是i=84}catch (Exception ex){MessageBox.Show($"瀏覽節點時出錯: {ex.Message}");}}private async Task BrowseNodeAsync(string nodeId, TreeNode parentTreeNode){var references = await opcUaClient.BrowseNodeReferenceAsync(nodeId);foreach (var reference in references){var childNode = parentTreeNode.Nodes.Add($"{reference.DisplayName} ({reference.NodeId})");// 如果是文件夾/對象類型,添加一個虛擬子節點以便展開if (reference.NodeClass == Opc.Ua.NodeClass.Object || reference.NodeClass == Opc.Ua.NodeClass.Variable){childNode.Nodes.Add("加載中...");}}}private async void treeNodes_BeforeExpand(object sender, TreeViewCancelEventArgs e){var node = e.Node;// 如果只有一個"加載中..."子節點,則實際加載子節點if (node.Nodes.Count == 1 && node.Nodes[0].Text == "加載中..."){try{node.Nodes.Clear();// 從節點文本中提取NodeIdvar nodeId = ExtractNodeIdFromTreeNode(node);if (!string.IsNullOrEmpty(nodeId)){await BrowseNodeAsync(nodeId, node);}}catch (Exception ex){MessageBox.Show($"加載子節點時出錯: {ex.Message}");node.Nodes.Add($"錯誤: {ex.Message}");}}}private string ExtractNodeIdFromTreeNode(TreeNode node){// 從類似 "DisplayName (ns=2;s=MyVariable)" 的文本中提取 "ns=2;s=MyVariable"var text = node.Text;var start = text.IndexOf('(') + 1;var end = text.IndexOf(')');if (start > 0 && end > start){return text.Substring(start, end - start);}return null;}private void MainForm_FormClosing(object sender, FormClosingEventArgs e){if (isConnected){DisconnectFromServer();}}}
}

3. 功能說明

  1. 連接/斷開服務器

    • 使用ConnectServerAsync方法異步連接
    • 使用Disconnect方法斷開連接
  2. 讀取節點數據

    • 使用ReadNodeAsync方法讀取單個節點值
    • 支持所有OPC UA數據類型
  3. 瀏覽服務器節點

    • 使用BrowseNodeReferenceAsync方法瀏覽節點引用
    • 實現樹形視圖的延遲加載
  4. 錯誤處理

    • 對所有OPC UA操作進行適當的錯誤處理

4. 擴展功能

你可以根據需要擴展此示例,添加以下功能:

  1. 寫入數據

    await opcUaClient.WriteNodeAsync(nodeId, value);
    
  2. 訂閱數據變化

    // 創建訂閱
    var subscription = new OpcUaHelper.Subscription(opcUaClient);// 添加監控項
    subscription.AddItem(nodeId);// 數據變化事件
    subscription.DataChangeReceived += (s, e) => 
    {// 處理數據變化
    };// 啟動訂閱
    await subscription.ApplyAsync();
    
  3. 調用方法

    var results = await opcUaClient.CallMethodByNodeIdAsync(objectNodeId, methodNodeId, inputArguments);
    

5. 注意事項

  1. 異步編程:所有OPC UA操作都應使用異步方法,避免阻塞UI線程。

  2. 錯誤處理:網絡操作容易出錯,確保有適當的錯誤處理和用戶反饋。

  3. 安全性:生產環境中可能需要配置安全策略和用戶憑據。

  4. 資源清理:確保在應用程序退出時正確斷開連接。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/89049.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/89049.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/89049.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

鴻蒙應用開發中的數據存儲:SQLite與Preferences全面解析

在鴻蒙(HarmonyOS)應用開發中,數據存儲是構建功能完整、用戶體驗良好的應用程序的關鍵環節。鴻蒙系統提供了多種數據存儲解決方案,其中SQLite數據庫和Preferences(偏好設置)是最常用的兩種方式。本文將深入…

夏至之日,共赴實時 AI 之約:RTE Open Day@AGI Playground 2025 回顧

每年 RTE 開發者社區的重磅活動—— RTE Open Day ,也在六月的 AGI Playground 現場開啟今年的行程。這是 RTE Open Day 第五期現場,這期我們的關鍵詞是 「Real-Time AI」 和 「Voice Agent」,不僅有來自社區的 16 個項目,還有兩場…

Tomcat性能調優指南

文章目錄 一、Tomcat性能調優概述為什么需要調優Tomcat? 二、Tomcat架構與性能關鍵點三、JVM調優1. 內存配置優化2. 垃圾回收優化3. 其他JVM優化參數 四、連接器(Connector)調優1. NIO vs APR/Native2. 高級NIO配置 五、線程池優化六、會話管理優化1. 會話超時配置2…

Swift 小技巧:用單邊區間優雅處理模糊范圍

進入正題之前先科普一下 Swift 區間的知識。 Swift 中的區間有兩種類型&#xff1a;閉區間和半開區間。 閉區間&#xff1a;用 a...b 表示&#xff0c;包含 a 和 b。半開區間&#xff1a;用 a..<b 表示&#xff0c;包含 a 但不包含 b。 舉個例子 想判斷一個數字是否在 0 …

Tang Prime 20K板OV2640例程

準備用Tang Prime 20K開發板進行OV2640攝像頭采集驗證。 Tang Primer 20K是由開源硬件廠商SiPEED矽速科技推出&#xff0c;是一款以 GW2A-LV18PG256C8/I7 為主芯片的核心板&#xff0c;準備了 2 個擴展板&#xff0c;Dock 和 Lite。板卡包含有HDMI輸出&#xff0c;DVP接口&…

基于Anaconda環境開發IntelliJ IDEA實用JSON轉Java實體插件

在軟件開發中&#xff0c;將JSON數據轉換為Java實體類是常見需求。借助Anaconda環境強大的包管理能力與IntelliJ IDEA的插件開發體系&#xff0c;我們可以打造一款高效實用的JSON轉Java實體插件&#xff0c;顯著提升開發效率。下面將從需求分析、技術選型、開發實現到優化部署&…

idea運行到遠程機器 和 idea遠程JVM調試

一、idea運行到遠程機器 適用場景&#xff0c;本地連接不上遠程機器的部分組件&#xff0c;如&#xff1a;redis、數據庫。 缺點&#xff1a;每次修改程序&#xff0c;會復制所有的 依賴和class 啟動比較慢。 工作原理&#xff1a;遠程機器和本機器&#xff0c;都會啟動一個端口…

微信小程序接入騰訊云短信驗證碼流程

以下是針對 AA公司微信小程序接入騰訊云短信驗證碼 的 全流程操作指南&#xff0c;包含資質申請、簽名/模板配置、代碼對接的完整解決方案&#xff1a; 一、資質申請&#xff08;必須通過審核才能發短信&#xff09; 1?? 進入資質管理頁 路徑&#xff1a;騰訊云控制臺 → 短…

阿里云OSS文件上傳完整實現方案

一、前言 阿里云對象存儲服務(OSS)是一種海量、安全、低成本、高可靠的云存儲服務。本文將詳細介紹如何在Spring Boot項目中集成阿里云OSS實現文件上傳功能。 二、準備工作 1. 獲取OSS配置信息 在開始前&#xff0c;您需要準備以下OSS配置信息&#xff1a; endpoint: OSS服…

【軟考--軟件設計師】10.2 關系型數據庫

10 模式分解 分解 模式分解:將一個關系模式分解為多個子模式 模式分解就是模式規范化的工具&#xff0c;模式分解使用無損連接和保持函數依賴來衡量模式分解后是否導致原有模式中部分信息丟失。 無損連接 保持函數依賴 11、事務管理 事務的ACID性質: (1)原子性(Atomicit…

python訓練day44 預訓練模型

預訓練模型發展史 預訓練模型的訓練策略 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms from torch.utils.data import DataLoader import matplotlib.pyplot as plt# 設置中文字體支持 plt.rcParams["…

[論文閱讀]MISSRce

論文title: MISSRec: Pre-training and Transferring Multi-modal Interest-aware Sequence Representation for Recommendation

Redis學習筆記——黑馬點評 附近商鋪到UV統計 完結

前言&#xff1a; 今天完結了Redis的所有實戰篇。 學習收獲&#xff1a; GEO數據結構&#xff1a; GEO就是Geolocation的簡寫形式&#xff0c;代表地理坐標。Redis在3.2版本中加入對Geo的支持&#xff0c;存儲、管理和操作地理空間數據的特殊數據結構&#xff0c;它能高效處…

【客戶端排查】mac電腦怎么查看客戶端的實時運行日志

先退出客戶端&#xff1b;打開訪達里的應用程序&#xff1b; 打開【顯示包內容】&#xff1b; 找到MacOS 雙擊里面的終端程序&#xff1b; 雙擊后&#xff0c;客戶端會自動啟動&#xff0c;且可以在終端中查看客戶端的實時日志啦~

HarmonyOS NEXT倉頡開發語言實戰案例:健身App

各位好&#xff0c;今日分享一個健身app的首頁&#xff1a; 這個頁面看起比之前的案例要稍微復雜一些&#xff0c;主要在于頂部部分&#xff0c;有重疊的背景&#xff0c;還有偏移的部分。重疊布局可以使用Stack容器實現&#xff0c;超出容器范圍的偏移可以使用負數間距來實現&…

TreeMap源碼分析 紅黑樹

今天嘗試刨一下TreeMap的祖墳。 底層結構對比 先來看一下與HashMap、LinkedHashMap和TreeMap的對比&#xff0c;同時就當是復習一下&#xff1a; HashMap使用數組存儲數據&#xff0c;并使用單向鏈表結構存儲hash沖突數據&#xff0c;同一個沖突桶中數據量大的時候&#xff…

華為云Flexus+DeepSeek征文|基于Dify構建拍照識題智能學習助手

華為云FlexusDeepSeek征文&#xff5c;基于Dify構建拍照識題智能學習助手 一、構建拍照識題智能學習助手前言二、構建拍照識題智能學習助手環境2.1 基于FlexusX實例的Dify平臺2.2 基于MaaS的模型API商用服務 三、構建拍照識題智能學習助手實戰3.1 配置Dify環境3.2 配置Dify工具…

題解:CF2120E Lanes of Cars

根據貪心&#xff0c;不難想到每次會把最長隊伍末尾的那輛車移動到最短隊伍的末尾。但由于 k k k 的存在&#xff0c;會導致一些冗余移動的存在。設需要挪動 C C C 輛車&#xff0c;則怒氣值可以表示為 f ( C ) k C f(C) kC f(C)kC&#xff0c;其中 f ( C ) f(C) f(C) 是…

Excel基礎:選擇和移動

本文演示Excel中基礎的選擇和移動操作&#xff0c;并在最后提供了一張思維導圖&#xff0c;方便記憶。 文章目錄 一、選擇1.1 基礎選擇1.1.1 選擇單個單元格1.1.2 選擇連續范圍 1.2 行列選擇1.2.1 選擇整行整列1.2.2 選擇多行多列 1.3 全選1.3.1 全選所有單元格1.3.2 智能選擇…

Java面試寶典:基礎四

80. int vs Integer 維度intInteger類型基本數據類型(8種之一)包裝類默認值0null應用場景性能敏感場景(計算密集)Web表單、ORM框架(區分null和0)特殊能力無提供工具方法(如parseInt())和常量(如MAX_VALUE)示例: