Java 使用 OPC UA的步骤详解

 更新时间:2026年01月29日 10:19:12   作者:夜行容忍  
使用Java与OPC UA (OPC Unified Architecture) 进行通信,可以使用开源的Eclipse Milo库,下面给大家介绍使用Eclipse Milo库与OPC UA服务器进行交互的步骤,感兴趣的朋友跟随小编一起看看吧

使用Java与OPC UA (OPC Unified Architecture) 进行通信,可以使用开源的Eclipse Milo库。以下是一个简单的指南,帮助你开始使用Eclipse Milo库与OPC UA服务器进行交互。

步骤一:引入Eclipse Milo库

你需要在项目中引入Eclipse Milo库。可以使用Maven或Gradle来管理依赖。

Maven依赖:

<dependency>
    <groupId>org.eclipse.milo</groupId>
    <artifactId>sdk-client</artifactId>
    <version>0.6.7</version>
</dependency>

Gradle依赖:

implementation 'org.eclipse.milo:sdk-client:0.6.7'

步骤二:创建并配置OPC UA客户端

下面是一个简单的示例代码,展示如何创建并配置一个OPC UA客户端,以及如何连接到OPC UA服务器。

import org.eclipse.milo.opcua.sdk.client.OpcUaClient;
import org.eclipse.milo.opcua.stack.core.types.builtin.unsigned.Unsigned;
import org.eclipse.milo.opcua.stack.core.types.structured.EndpointDescription;
import org.eclipse.milo.opcua.stack.core.types.structured.EndpointDescriptionArray;
import org.eclipse.milo.opcua.stack.core.util.EndpointUtil;
import java.util.concurrent.CompletableFuture;
public class OpcUaClientExample {
    public static void main(String[] args) throws Exception {
        String endpointUrl = "opc.tcp://localhost:4840";  // 替换为你的OPC UA服务器地址
        // 找到服务器的端点
        EndpointDescription[] endpoints = OpcUaClient.getEndpoints(endpointUrl).get();
        // 选择合适的端点
        EndpointDescription endpoint = EndpointUtil.select(endpoints, "None", "None").orElseThrow(() ->
                new Exception("没有找到合适的端点"));
        // 创建客户端
        OpcUaClient client = OpcUaClient.create(endpoint);
        // 连接到服务器
        CompletableFuture<Void> future = client.connect();
        future.whenComplete((result, ex) -> {
            if (ex != null) {
                ex.printStackTrace();
            } else {
                System.out.println("连接成功!");
                // 在此添加你的业务逻辑
            }
        });
        future.get(); // 等待连接完成
    }
}

步骤三:读取和写入变量

下面是如何读取和写入OPC UA服务器上的变量的示例。

import org.eclipse.milo.opcua.sdk.client.OpcUaClient;
import org.eclipse.milo.opcua.stack.core.types.builtin.DataValue;
import org.eclipse.milo.opcua.stack.core.types.builtin.NodeId;
import org.eclipse.milo.opcua.stack.core.types.builtin.Variant;
import java.util.concurrent.CompletableFuture;
public class ReadWriteExample {
    public static void main(String[] args) throws Exception {
        OpcUaClient client = OpcUaClient.create("opc.tcp://localhost:4840").get();
        client.connect().get();
        NodeId nodeId = new NodeId(2, "MyVariable");
        // 读取变量值
        CompletableFuture<DataValue> readFuture = client.readValue(0, null, nodeId);
        DataValue value = readFuture.get();
        System.out.println("读取到的值: " + value.getValue().getValue());
        // 写入变量值
        Variant variant = new Variant(42); // 替换为你要写入的值
        DataValue newValue = new DataValue(variant);
        CompletableFuture<Void> writeFuture = client.writeValue(nodeId, newValue);
        writeFuture.get();
        System.out.println("值已写入");
    }
}

总结

使用Eclipse Milo库可以方便地与OPC UA服务器进行通信。通过上述步骤,你可以快速开始使用Java与OPC UA进行交互。可以根据需求扩展和定制客户端的功能,如订阅数据更改、浏览节点等。

到此这篇关于Java 使用 OPC UA的步骤详解的文章就介绍到这了,更多相关java使用opc ua内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot外部化配置的最佳实践指南

    SpringBoot外部化配置的最佳实践指南

    这篇文章主要介绍了SpringBoot外部化配置的核心思想和实现方式,包括配置来源、加载优先级、Profile特定配置、YAML与Properties对比、通配符路径应用、调试工具等内容,为多环境部署和动态管理配置提供了详细实践建议,需要的朋友可以参考下
    2025-10-10
  • Intellij IDEA 热部署处理方法(图解)

    Intellij IDEA 热部署处理方法(图解)

    本文通过图文并茂的形式给大家介绍了Intellij IDEA 热部署处理方法,需要的朋友可以参考下
    2018-02-02
  • 学习Java HashMap,看这篇就够了

    学习Java HashMap,看这篇就够了

    这篇文章主要介绍了Java HashMap的相关资料,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • Jmeter安装的方法步骤详解

    Jmeter安装的方法步骤详解

    这篇文章主要介绍了Jmeter安装的方法步骤详解,Apache JMeter是Apache组织开发的基于Java的压力测试工具。用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域,需要的朋友可以参考下
    2019-07-07
  • SpringBoot实现多文件上传的详细示例代码

    SpringBoot实现多文件上传的详细示例代码

    文件上传中并没有什么太多的知识点,下面这篇文章主要给大家介绍了关于SpringBoot实现多文件上传的详细示例,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • Java 中分形图的几种方法详解

    Java 中分形图的几种方法详解

    这篇文章主要介绍了Java 中几种分形的方法详解的相关资料,需要的朋友可以参考下
    2017-07-07
  • 使用jmx exporter采集kafka指标示例详解

    使用jmx exporter采集kafka指标示例详解

    这篇文章主要为大家介绍了使用jmx exporter采集kafka指标示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • Feign远程调用丢失请求头问题

    Feign远程调用丢失请求头问题

    本文介绍了在服务端项目中如何解决资源访问限制问题,首先介绍了问题的产生,然后详细解析了源码,最后提出了解决方案,解决方案包括同步和异步两种,同步时直接向Spring容器注入RequestInterceptor拦截器
    2024-09-09
  • Java使用HttpClient实现Post请求实例

    Java使用HttpClient实现Post请求实例

    本篇文章主要介绍了Java使用HttpClient实现Post请求实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • java分形绘制科赫雪花曲线(科赫曲线)代码分享

    java分形绘制科赫雪花曲线(科赫曲线)代码分享

    部分与整体以某种形式相似的形,称为分形,科赫曲线是一种外形像雪花的几何曲线,所以又称为雪花曲线,它是分形曲线中的一种,画法如下
    2013-12-12

最新评论