基于Java的OPCDA采集中间件

1.软件功能及技术特点简介:

软件功能及技术特点简介:

OPCDA是基于Java语言开发的OPC client(OPC客户端)跨平台中间件软件,他支持OPC SERVER的OPC DA1.0/2.0/3.0。OPCDA实时采集数据(包括实时数据、报警数据、历史变化数据等),同时提供MQTT发布订阅功能,为工业大数据平台提供现场基础数据支撑,且适用于所有的工业控制行业。

1、支持读取OPC DA1.0、2.0、3.0;

2、支持MQTT物联网功能,发布内容包括实时值、报警等内容;

3、支持操作系统(Windows);

4、适用于工业互联进程中的车间-车间、车间-厂集控中心、厂集控中心-地区集控中

心。

5.采集频率在5s以上,支持5000点位采集。

2.程序配置


1.jre opcdaclient.exe运行所需的java环境

2.lib opcda采集需要的dll文件

3.config.properties 配置文件,程序会默认读取同级目录下的配置文件

4.pointconfig.xlsx文件是点位表,程序会读取同级目录下的pointconfig.xlsx

3.程序界面

双击opcdaclient.exe

OPC服务设置:

输入OPC服务器地址点击游览,查找opcDA服务,点击连接。

点击同步指标,将pointconfig.xlsx文件的点位信息同步显示出来。

采集频率自定义设置不能低于1000ms

MQTT服务设置

输入服务地址,端口 ,用户名和密码。点击连接,如果成功日志会显示MQTT连接成功。

会自动按照采集频率去发送MQTT。

4.部分代码

java 复制代码
```java
// 主面板使用BorderLayout
        JPanel mainPanel = new JPanel(new BorderLayout(10, 10));
        mainPanel.setBorder(BorderFactory.createEmptyBorder(10, 10, 10, 10));

        // 左侧面板(使用BorderLayout垂直排列)
        JPanel leftPanel = new JPanel(new BorderLayout(5, 5));

        // 顶部面板 - OPC和MQTT设置
        JPanel settingsPanel = new JPanel(new GridLayout(2, 1, 5, 5));
        settingsPanel.add(createOpcPanel());
        settingsPanel.add(createMqttPanel());
        leftPanel.add(settingsPanel, BorderLayout.NORTH);

        // 中间表格
        dataTable = new JTable(new DefaultTableModel(
                new String[]{"ItemID", "类型", "值", "质量"}, 0));
        JScrollPane tableScroll = new JScrollPane(dataTable);
        tableScroll.setBorder(BorderFactory.createTitledBorder("数据表格"));
        leftPanel.add(tableScroll, BorderLayout.CENTER);

        // 右侧日志面板(使用JPanel包装确保正确布局)
        JPanel rightPanel = new JPanel(new BorderLayout());
        rightPanel.setPreferredSize(new Dimension(350, 0));
java 复制代码
// 新增方法:更新采集频率
    private void updateCollectFrequency() {
        try {
            int newInterval = Integer.parseInt(collectFrequencyField.getText());
            if (newInterval < 999) {
                logMessage("警告: 采集频率不能低于999ms");
                return;
            }

            if (newInterval != collectInterval) {
                collectInterval = newInterval;
                logMessage("采集频率已设置为: " + collectInterval + "ms");

                // 如果正在采集,则重新启动定时器
                if (collectTimer != null && collectTimer.isRunning() &&
                        jopc != null && jopc.ping()) {
                    //startDataCollection(); // 这会自动停止旧的定时器并创建新的
                    readAllIndicatorValues();
                }
            }
        } catch (NumberFormatException e) {
            logMessage("错误: 请输入有效的数字");
        }
    }

如有需要请私聊。

相关推荐
音符犹如代码4 小时前
ZooKeeper 实战指南:从入门到场景解析
分布式·微服务·zookeeper·云原生·中间件·架构
21991 天前
消息中间件2025技术全景与选型指南
中间件·开源·rabbitmq
油泼辣子多加1 天前
【信创】中间件对比
人工智能·深度学习·算法·中间件
他是龙5512 天前
41-ASP应用与IIS中间件漏洞实战
中间件
眠りたいです2 天前
Docker:容器虚拟化技术基础-namespace,cgroups,资源管理与LXC
运维·docker·中间件·容器
济南java开发,求内推2 天前
中间件升级
中间件
六行神算API-天璇3 天前
架构思考:大模型作为医疗科研的“智能中间件”
人工智能·中间件·架构·数据挖掘·ar
yours_Gabriel3 天前
【一】常用中间件及用处
中间件
feathered-feathered3 天前
Redis基础知识+RDB+AOF(面试)
java·数据库·redis·分布式·后端·中间件·面试
Geoking.3 天前
什么是中间件?有哪些中间件?
中间件