FinsTCP协议的Java Socket

2024-06-12 09:38
文章标签 java 协议 socket finstcp

本文主要是介绍FinsTCP协议的Java Socket,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  在网上并无找到关于欧姆龙的FinsTcp协议的调试工具和仿真软件,但找到的一部分资料有使用一些Tcp/UdpSocket调试工具跟下位机PLC进行网络通信,因此个人认为上位机可以使用Java编写程序,通过Socket发送相关指令给下位机,进行握手连接和数据获取。

        下位机的默认端口是9600,上位机通过该端口与下位机相连。

        下面给出模拟数据,其中上位机ip假设为192.1.1.24;下位机ip假设为192.1.1.48

        1)通信前要进行握手连接,其中上位机发给下位机的握手格式如下:


其发送的指令为:46494E53(FINS)0000000C(长度12字节)00000000(命令代码)00000000(错误代码)00000030(客户端节点号,ip的最后位)

        2)下位机返回握手连接响应,其响应格式如下:


其返回的指令为:46494E53(FINS)00000010(长度16字节)00000001(命令代码)00000000(错误代码)00000030(客户端节点号)00000018(服务器节点号)

        3)之后便可进行通信,通信过程中Tcp命令格式如下:


其中Fins帧的格式如下:


给出一个例子:46494E53(FINS)0000001A(数据长度26)00000002(命令代码)00000000(错误代码)80|00|02|00|18|00|00|30|00|00|0101|B1|0064|00|0001(FINS命令帧)

                  FinsFrame段解析:

                           1)80:ICF段,80标识要求有回复,81标识不要求有回复;

                         2)00:RSV段,默认为00;

                           3)02:GCT段,表示穿过的网络层数量,0层为02,1层为01,2层为00;

                           4)00:DNA段,目的网络地址;

                           5)18:DA1段,目的节点地址,默认是目的PLC的ip地址的最后位(上述PLC的ip地址为192.1.1.24,因此该段为18);

                           6)00:DA2段,目的单元地址;

                           7)00:SNA段,源网络地址;

                           8)30:SA1段,源节点地址,即上位机ip地址的最后位(上述上位机的ip地址为192.1.1.48,因此该段为30);

                           9)00:SA2段,源单元地址;

                           10)00:SID段;

                         11)0101:读写具体命令,0101表示读,0102表示写;

                         12)B1:相应区域和具体方式,B1表示WR区按字,B0表示CIO区按字,30   表示CIO区按位;

                          13)0064:寄存器地址;

                          14)00:位地址,即读取数据的首地址;(原本为000000,在读的时候仅前两个字节有效,因此为00)

                          15)0001:读取的数量。

                  得到的响应反馈为:

                           46494E53(FINS)00000018(数据长度24)00000002(命令代码)0000 0000(错误代码)C0 00 02 00 30 00 00 18 0000 01 01 00 00 12 34 (FINS反馈帧,其中1234是反馈数据)

 

以上是关于上位机用Socket来获取下位机PLC数据的相关方法和指令,整个过程并无进行测试操作,其可行性无法确定,欢迎提出纠正。我也会继续查找相关资料和模拟软件确定方案。



这篇关于FinsTCP协议的Java Socket的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏