ModbusTCP报文格式说明

modbus tcp数据报文结构

请求:00 00 00 00 00 06 09 03 00 00 00 01

响应:00 00 00 00 00 05 09 03 02 12 34


  一次modbus tcp读取保持寄存器的通信分析(省略了ip/tcp头):从左向右分析该数据报文:

请求:

00 00为此次通信事务处理标识符,一般每次通信之后将被要求加1以区别不同的通信数据报文;

00 00表示协议标识符,00 00为modbus协议;

00 06为数据长度,用来指示接下来数据的长度,单位字节;

09为设备地址,用以标识连接在串行线或者网络上的远程服务端的地址。以上七个字节也被称为modbus报文头;

03为功能码,此时代码03为读取保持寄存器数据;

00 00为起始地址;

00 01为寄存器数量,(word数量)。

响应:

00 00为此次通信事务处理标识符,应答报文要求与先前对应的请求保持一致;

00 00为协议标识符,与先前对应的请求保持一致;

00 05为数据长度,用来指示接下来数据的长度,单位字节;

09为设备地址,应答报文要求与先前对应的请求保持一致;

03为功能码,正常情况下应答报文要求与先前对应的请求保持一致,如果出错则返回80h+先前的功能码;

02指示接下来数据的字节长度;

12 34为被读取的保持寄存器中的数据值,即要求被读取的地址为00 00的保持寄存器中的数值为1234h。

  • 7
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Modbus TCP是一种基于TCP/IP协议的通信协议,用于实现工业自动化系统中设备间的数据通信。它定义了一套简单且有效的报文格式Modbus TCP报文格式按照功能类型分为读操作和写操作两种。下面我将对其进行详细说明。 1. 读操作报文格式: - 事务标识符(Transaction Identifier):用于标识请求和响应之间的关联。 - 协议标识符(Protocol Identifier):用于表示Modbus TCP协议标识。 - 长度字段(Length):表示Modbus TCP帧中数据的字节数。 - 单元标识符(Unit Identifier):用于在一个Modbus TCP网络中区分不同的设备。 - 功能码(Function Code):标识请求的功能类型,如读取离散输入、读取保持寄存器等。 - 数据区(Data):包含读取或写入的数据。 2. 写操作报文格式: - 事务标识符(Transaction Identifier)、协议标识符(Protocol Identifier)、长度字段(Length)、单元标识符(Unit Identifier)的含义与读操作相同。 - 功能码(Function Code):与读操作不同的是,写操作的功能码另外还包含地址字段(Address)和数据字段(Data)。 - 地址字段(Address):表示要写入的寄存器或数据的地址。 - 数据字段(Data):表示要写入寄存器或数据的值。 Modbus TCP报文格式简洁而灵活,方便设备之间进行数据交互。它支持读写不同类型的数据,如离散输入、线圈状态、输入寄存器、保持寄存器等。通过Modbus TCP报文,设备可以实现对其他设备的监测、控制和数据采集等操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值