通过Milo实现的OPC UA客户端连接并订阅Prosys OPC UA Simulation Server模拟服务器

本文主要是介绍通过Milo实现的OPC UA客户端连接并订阅Prosys OPC UA Simulation Server模拟服务器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

前面我们搭建了一个本地的 PLC 仿真环境,并通过 KEPServerEX6 读取 PLC 上的数据,最后还使用 UAExpert 作为 OPC 客户端完成从 KEPServerEX6 这个OPC服务器的数据读取与订阅功能:SpringBoot集成Milo库实现OPC UA客户端:连接、遍历节点、读取、写入、订阅与批量订阅。

注意,如果实际工作中,仅仅需要测试下 OPC UA 客户端的功能,那么就Duck不必搭建本地的 PLC 仿真环境,而是借助一些 OPC UA 服务端的模拟工具。在这篇文章中,我们将使用 Prosys OPC UA Simulation Server 作为 OPC UA 的服务端,并通过我们前面自己实现的 OPC UA 客户端来连接这个模拟的 OPC UA 的服务器,即:

通过 Milo 实现的 OPC UA 客户端连接 Prosys OPC UA Simulation Server 模拟的 OPC UA 服务器。

下载安装:Prosys OPC UA Simulation Server

https://downloads.prosysopc.com/opc-ua-simulation-server-downloads.php

模拟OPC UA服务器

双击启动 Prosys OPC UA Simulation Server 后,首页显示了服务器的地址信息。

2023-04-16-Home.jpg

如果需要修改这个默认的连接地址,可通过 Endpoints 菜单进行设置(我这里用的是默认的地址)。

2023-04-16-Endpoints.jpg

Objects 菜单下,可以看到 Prosys OPC UA Simulation Server 默认自带了计数器、随机数、梯形图、锯齿波、正弦波、三角波等节点,可通过 OPC UA 客户端进行读取测试。

2023-04-16-Objects.jpg

基于Milo实现的OPC UA客户端测试

作为示例,以下通过连接服务器(匿名连接)读取指定节点的值以及订阅指定节点来完成与 Prosys OPC UA Simulation Server 模拟 OPC UA 服务器的操作。

在实际编码测试之前,可以先通过 UAExpert 作为 OPC 客户端完成从模拟服务器的数据读取与订阅功能,顺便再次明确下 NodeId 的信息。

2023-04-16-UAExpert.jpg

public class OpcUaStart {public void start() throws Exception {OpcUaClientService opcUaClientService = new OpcUaClientService();// 与OPC UA服务端建立连接,并返回客户端实例OpcUaClient client = opcUaClientService.connectOpcUaServer("你的机器名称", "53530", "/OPCUA/SimulationServer");// 两种方式定义节点NodeId nodeId = new NodeId(3, 1002); // 注意第2个参数类型为数字
//        NodeId nodeId = NodeId.parse("ns=3;i=1002"); // 通过parse静态方法定义// 读取指定节点的值opcUaClientService.readNodeValue(client, nodeId);// 订阅指定节点opcUaClientService.subscribe(client, nodeId);}
}

测试结果如下:
2023-04-16-Result.jpg

可能遇到的问题

Prosys OPC UA Simulation Server 界面上没有 Endpoints 菜单?

解决方法: Prosys OPC UA Simulation Server 界面上如果没有 Endpoints 菜单,可通过左上角的 Options 菜单 Switch to Expert Mode 切换一下。

2023-04-16-Options.jpg

基于Milo实现的OPC UA客户端如何读取、订阅 Prosys OPC UA Simulation Server 中的节点数据?

StatusCode{name=Bad_NodeIdUnknown, value=0x80340000, quality=bad}

2023-04-16-Cursor.jpg

原因分析: 根据状态提示,再结合我们读取节点数据的实现: readNodeValue 方法关键的参数分别为: int namespaceIndex , String identifier 。之前连接 KEPServerMilo Serveridentifier 的类型都是 String ,可以正常读取,但是连接 Prosys OPC UA Simulation Server 后,无法读取,我尝试直接改为 int 类型后,读取成功。

解决方法:

方法1:将 readNodeValue 方法的 String identifier 参数改为 int identifier ,即在传参时使用整数类型,可以通过增加一个重载的方法实现。

public void readNodeValue(OpcUaClient client, int namespaceIndex, int identifier)

方法2: 修改 readNodeValue 方法直接接收 NodeId 类型,这时可以通过各种方式定义 NodeIdNodeId 提供了各种重载和解析方法。

public void readNodeValue(OpcUaClient client, NodeId nodeId)// 方式1:构造方法定义NodeId,注意第2个参数类型为数字
NodeId nodeId = new NodeId(3, 1002); // 方式2:静态解析定义NodeId
NodeId nodeId = NodeId.parse("ns=3;i=1002");

Note:方式2:静态解析定义NodeId,这种方法是我通过基于 GPT-4 大模型的 Cursor 问答得知的:Cursor编程初体验,搭载GPT-4大模型,你的AI助手,自然语言编程来了。

2023-04-15-MiloResult.jpg

Reference

Prosys_OPC_UA_Simulation_Server_UserManual用户手册

Source Code

https://github.com/heartsuit/demo-spring-boot/tree/master/springboot-opcua


If you have any questions or any bugs are found, please feel free to contact me.

Your comments and suggestions are welcome!

这篇关于通过Milo实现的OPC UA客户端连接并订阅Prosys OPC UA Simulation Server模拟服务器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/708869

相关文章

C#高效实现在Word文档中自动化创建图表的可视化方案

《C#高效实现在Word文档中自动化创建图表的可视化方案》本文将深入探讨如何利用C#,结合一款功能强大的第三方库,实现在Word文档中自动化创建图表,为你的数据呈现和报告生成提供一套实用且高效的解决方... 目录Word文档图表自动化:为什么选择C#?从零开始:C#实现Word文档图表的基本步骤深度优化:C

Nginx服务器部署详细代码实例

《Nginx服务器部署详细代码实例》Nginx是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务,:本文主要介绍Nginx服务器部署的相关资料,文中通过代码... 目录Nginx 服务器SSL/TLS 配置动态脚本反向代理总结Nginx 服务器Nginx是一个‌高性

nginx跨域访问配置的几种方法实现

《nginx跨域访问配置的几种方法实现》本文详细介绍了Nginx跨域配置方法,包括基本配置、只允许指定域名、携带Cookie的跨域、动态设置允许的Origin、支持不同路径的跨域控制、静态资源跨域以及... 目录一、基本跨域配置二、只允许指定域名跨域三、完整示例四、配置后重载 nginx五、注意事项六、支持

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Prometheus+cpolar如何在手机上也能监控服务器状态?

《Prometheus+cpolar如何在手机上也能监控服务器状态?》本文强调了通过Cpolar这一内网穿透工具,轻松突破Prometheus仅限于局域网访问的限制,实现外网随时随地访问监控数据,教你... 目录前言1.安装prometheus2.安装cpolar实现随时随地开发3.配置公网地址4.保留固定

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp