跳到主要内容

二次开发协议

功能码介绍

功能码备注
01读线圈状态读继电器状态
02读离散输入状态读输入状态
03读保持寄存器读取地址、版本
05写单线圈写单个继电器
06写单寄存器设置波特率,地址
0F写多个线圈写继电器状态
10写多个寄存器设置多个寄存器

寄存器地址介绍

地址 (HEX)地址存储内容寄存器取值权限Modbus 功能码
0x0000 ~ 0x0007通道 1~通道 8 继电器地址0xFF00: 继电器开启;
0x0000: 继电器关闭;
0x5500: 继电器翻转;
读/写0x01, 0x05, 0x0F
0x00FF操作全部继电器0xFF00: 继电器全部开启;
0x0000: 继电器全部关闭;
0x5500: 继电器全部翻转;
0x05
0x0100 ~ 0x0107通道 1~通道 8 继电器翻转地址0xFF00: 继电器翻转;
0x0000: 继电器不变;
0x05, 0x0F
0x01FF操作全部继电器翻转0xFF00: 继电器全部翻转;
0x0000: 继电器全部不变;
0x05
0x0200 ~ 0x0207通道 1~通道 8 继电器闪开延时时间为数据 * 100 ms
数值:0x0007, 延时:7 * 100 ms = 700 ms
0x05
0x0400 ~ 0x0407通道 1~通道 8 继电器闪闭延时时间为数据 * 100 ms
数值:0x0007, 延时:7 * 100 ms = 700 ms
0x05
0x10000 ~ 0x10007通道 1~通道 8 输入地址表示 1~8 输入通道状态0x02
0x41000 ~ 0x41007通道 1~通道 8 继电器控制模式0x0000 ~ 0x0003 四种控制模式读/写0x03, 0x06, 0x10
0x44000设备地址直接存储 Modbus 地址
设备地址:0x0001
0x03
0x48000软件版本转为十进制然后小数点左移两位即表示软件版本
0x0064 = 100 = V1.00
0x03

操作指令介绍

控制单个继电器

发送码:01 05 00 00 FF 00 8C 3A

字段含义备注
01设备地址固定 0x01
0505 指令控制继电器指令
00 00地址要控制继电器的寄存器地址,0x0000 - 0x0007
FF 00指令0xFF00: 继电器开启;
0x0000: 继电器关闭;
0x5500: 继电器翻转;
8C 3ACRC16前 6 字节数据的 CRC16 校验和

返回码: 01 05 00 00 FF 00 8C 3A

字段含义备注
01设备地址固定 0x01
0505 指令控制继电器指令
00 00地址要控制继电器的寄存器地址,0x0000 - 0x0007
FF 00指令0xFF00: 继电器开启;
0x0000: 继电器关闭;
0x5500: 继电器翻转;
8C 3ACRC16前 6 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

0 号继电器开启 : 01 05 00 00 FF 00 8C 3A
0 号继电器关闭 : 01 05 00 00 00 00 CD CA
1 号继电器开启 : 01 05 00 01 FF 00 DD FA
1 号继电器关闭 : 01 05 00 01 00 00 9C 0A
2 号继电器开启 : 01 05 00 02 FF 00 2D FA
2 号继电器关闭 : 01 05 00 02 00 00 6C 0A
3 号继电器开启 : 01 05 00 03 FF 00 7C 3A
3 号继电器关闭 : 01 05 00 03 00 00 3D CA
0 号继电器翻转 : 01 05 00 00 55 00 F2 9A
1 号继电器翻转 : 01 05 00 01 55 00 A3 5A
2 号继电器翻转 : 01 05 00 02 55 00 53 5A
3 号继电器翻转 : 01 05 00 03 55 00 02 9A

控制全部继电器

发送码:01 05 00 FF FF 00 BC 0A

字段含义备注
01设备地址固定 0x01
0505 指令控制继电器指令
00 FF地址固定 0x00FF
FF 00指令0xFF00: 继电器全部开启;
0x0000: 继电器全部关闭;
0x5500: 继电器全部翻转;
BC 0ACRC16前 6 字节数据的 CRC16 校验和

返回码: 01 05 00 FF FF 00 BC 0A

字段含义备注
01设备地址固定 0x01
0505 指令控制继电器指令
00 FF地址固定 0x00FF
FF 00指令0xFF00: 继电器全部开启;
0x0000: 继电器全部关闭;
0x5500: 继电器全部翻转;
BC 0ACRC16前 6 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

全部继电器开启 : 01 05 00 FF FF 00 BC 0A
全部继电器关闭 : 01 05 00 FF 00 00 FD FA
全部继电器翻转 : 01 05 00 FF 55 00 C2 AA

读取继电器状态

发送码:01 01 00 00 00 08 3D CC

字段含义备注
01设备地址固定 0x01
0101 指令查询继电器状态指令
00 00起始地址继电器起始地址,0x0000 - 0x0007
00 08继电器数量不能超过最大继电器数量
3D CCCRC16前 6 字节数据的 CRC16 校验和

返回码:01 01 01 00 51 88

字段含义备注
01设备地址固定 0x01
0101 指令查询继电器状态指令
01字节数返回状态信息的所有字节数。
00查询的状态返回的继电器状态
Bit0: 起始继电器状态;
Bit1: 下个继电器状态,
依次类推,高端空闲位为零
51 88CRC16前 4 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

发送 : 01 01 00 00 00 08 3D CC   //查询全部继电器
返回 : 01 01 01 00 51 88 //全部继电器关闭
发送 : 01 01 00 02 00 01 5C 0A //查询 2 号继电器
返回 : 01 01 01 01 90 48 //1 号继电器开启
发送 : 01 01 00 01 00 03 2D CB //查询 1,2,3 号继电器状态
返回 : 01 01 01 05 91 8B //1、3 号继电器开启,2 号继电器关闭

写继电器状态

发送码:01 0F 00 00 00 08 01 FF BE D5

字段含义备注
01设备地址固定 0x01
0F0F 指令写继电器状态指令
00 00继电器起始地址要控制继电器的寄存器地址,0x0000 - 0x0007
00 08继电器数量操作继电器数量,不能超过最大继电器数量
01字节数量状态字节数
FF继电器状态Bit0: 起始继电器状态;
Bit1: 下个继电器状态,
依次类推,高端空闲位则为零
BE D5CRC16前 6 字节数据的 CRC16 校验和

返回码:01 0F 00 00 00 08 54 0D

字段含义备注
01设备地址固定 0x01
0F0F 指令全部寄存器控制指令
00 00地址继电器起始地址
00 08继电器数量写入继电器数量
54 0DCRC16前 6 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

继电器全部开启 : 01 0F 00 00 00 08 01 FF BE D5
继电器全部关闭 : 01 0F 00 00 00 08 01 00 FE 95
0-1 开; 3-7 关 : 01 0F 00 00 00 08 01 03 BE 94
1,2,3 继电器开启 : 01 0F 00 01 00 03 01 07 F3 55

继电器闪开闪闭指令

发送码:01 05 02 00 00 07 8D B0

字段含义备注
01设备地址固定 0x01
0505 指令单个控制指令
02指令02 为闪开指令,04 为闪闭指令
00继电器地址要控制的继电器地址,0x00 ~ 0x07
00 07间隔时间延时时间为数据 * 100 ms
数值:0x0007,延时:7 * 100 ms = 700 ms
闪开闪闭的时间最大设置为 0x7FFF
8D B0CRC16前 6 字节数据的 CRC16 校验和

返回码:01 05 02 00 00 07 8D B0

字段含义备注
01设备地址固定 0x01
0505 指令单个控制指令
02指令02 为闪开指令,04 为闪闭指令
00继电器地址要控制的继电器地址,0x00 ~ 0x07
00 07间隔时间延时时间为数据 * 100 ms
数值:0x0007,延时:7 * 100 ms = 700 ms
闪开闪闭的时间最大设置为 0x7FFF
8D B0CRC16前 6 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

0 号继电器闪开 : 01 05 02 00 00 07 8D B0  //700MS = 7*100MS = 700MS
1 号继电器闪开 : 01 05 02 01 00 08 9C 74 //800MS
0 号继电器闪闭 : 01 05 04 00 00 05 0C F9 //500MS
1 号继电器闪闭 : 01 05 04 01 00 06 1D 38 //600MS

读取输入状态

发送码:01 02 00 00 00 08 79 CC

字段含义备注
01设备地址固定 0x01
0202 指令读取输入状态指令
00 00输入起始地址输入起始地址,0x0000 - 0x0007
00 08寄存器数量读取输入通道数量,不能超过最大输入通道
79 CCCRC16前 6 字节数据的 CRC16 校验和

返回码:01 02 01 00 A1 88

字段含义备注
01设备地址固定 0x01
0202 指令读取输入状态指令
01字节数返回状态信息的所有字节数。
00查询的状态返回的输入状态
Bit0: 起始输入通道状态;
Bit1: 下个输入通道状态,
依次类推,高端空闲位则为零
A1 88CRC16前 4 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

发送 : 01 02 00 00 00 08 79 CC    //查询全部输入通道
返回 : 01 01 01 00 51 88 //输入全部没有触发
发送 : 01 02 00 00 00 08 79 CC //查询全部输入通道
返回 : 01 02 01 41 61 B8 //1、7 通道输入触发,其余通道没有触发
发送 : 01 02 00 01 00 03 69 CB //查询 2,3,4 输入通道
返回 : 01 02 01 03 E1 89 //2,3 通道输入触发,4 通道没有触发

读取继电器控制模式

发送码:01 03 10 00 00 08 40 CC

字段含义备注
01设备地址固定 0x01
0303 指令读取保持寄存器
10 00寄存器起始地址0x1000 - 0x1007 对应 1~8 输入通道
00 08寄存器数量读取寄存器数量,最多 8 个通道
40 CCCRC16前 6 字节数据的 CRC16 校验和

返回码:01 03 10 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 E4 59

字段含义备注
01设备地址固定 0x01
0303 指令读保持寄存器
10字节数返回状态信息的所有字节数。
00 00 ~ 00 00控制模式表示 1 - 8 继电器控制模式,0x0000 ~ 0x0003 表示四种控制模式
0x0000: 正常模式,继电器受指令直接控制;
0x0001: 联动模式,继电器状态和对应输入通道状态一致;
0x0002: 翻转模式,输入通道输入一个脉冲对应的继电器状态翻转一次
0x0003: 跳变模式,输入通道电平跳变一次对应的继电器状态翻转一次
⚠️ 注意:除了联动模式外,其他模式都同时支持通过指令控制继电器。
E4 59CRC16前 6 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

读取 1-8 号继电器控制模式 : 01 03 10 00 00 08 40 CC 
读取 1 号继电器控制模式 : 01 03 10 00 00 01 80 CA
读取 2 号继电器控制模式 : 01 03 10 01 00 01 D1 0A
读取 3-5 号继电器控制模式 : 01 03 10 02 00 03 A0 CB

设置单继电器控制模式

发送码:01 06 10 00 00 01 4C CA

字段含义备注
01设备地址固定 0x01
0606 指令写单个寄存器指令
10 00寄存器起始地址0x1000 - 0x1007 对应 1~8 通道继电器控制模式
00 01控制模式表示 1 - 8 继电器控制模式,0x0000 ~ 0x0003 表示四种控制模式
0x0000: 正常模式,继电器受指令直接控制;
0x0001: 联动模式,继电器状态和对应输入通道状态一致;
0x0002: 翻转模式,输入通道输入一个脉冲对应的继电器状态翻转一次
0x0003: 跳变模式,输入通道电平跳变一次对应的继电器状态翻转一次
⚠️ 注意:除了联动模式外,其他模式都同时支持通过指令控制继电器。
4C CACRC16前 6 字节数据的 CRC16 校验和

返回码: 01 06 10 00 00 01 4C CA

字段含义备注
01设备地址固定 0x01
0606 指令写单个寄存器指令
10 00寄存器起始地址0x1000 - 0x1007 对应 1~8 通道继电器控制模式
00 01控制模式继电器控制模式,0x0000 ~ 0x0003 表示四种控制模式
4C CACRC16前 6 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

设置 1 继电器为联动模式 : 01 06 10 00 00 01 4C CA
设置 2 继电器为翻转模式 : 01 06 10 01 00 02 5D 0B

设置多继电器控制模式

发送码:01 10 10 00 00 08 10 00 01 00 01 00 01 00 01 00 01 00 01 00 01 00 01 7C B1

字段含义备注
01设备地址固定 0x01
10写多寄存器指令-
10 00寄存器起始地址0x1000 - 0x1007 对应 1~8 通道继电器控制模式
00 08寄存器数量设置寄存器数量,最多 8 个通道
10字节数量-
00 01 ~ 00 01控制模式表示 1 - 8 继电器控制模式,0x0000 ~ 0x0003 表示四种控制模式
0x0000: 正常模式,继电器受指令直接控制;
0x0001: 联动模式,继电器状态和对应输入通道状态一致;
0x0002: 翻转模式,输入通道输入一个脉冲对应的继电器状态翻转一次
0x0003: 跳变模式,输入通道输入状态改变一次对应的继电器状态翻转一次
⚠️ 注意:除了联动模式外,其他模式都同时支持通过指令控制继电器。
7C B1CRC16前 6 字节数据的 CRC16 校验和

返回码: 01 10 10 00 00 08 C5 0F

字段含义备注
01设备地址固定 0x01
10写多寄存器指令-
10 00寄存器起始地址0x1000 - 0x1007 对应 1~8 通道继电器控制模式
00 08寄存器数量设置寄存器数量,最多 8 个通道
C5 0FCRC16前 6 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

设置 1-8 通道继电器为正常模式:01 10 10 00 00 08 10 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 0B 5C
设置 1-8 通道继电器为联动模式:01 10 10 00 00 08 10 00 01 00 01 00 01 00 01 00 01 00 01 00 01 00 01 7C B1
设置 3-5 通道继电器为翻转模式:01 10 10 02 00 03 06 00 02 00 02 00 02 4A 4B

读取软件版本指令

发送码:01 03 80 00 00 01 AD CA

字段含义备注
01设备地址固定 0x01
0303 指令读保持寄存器
80 00指令寄存器0x8000 为读取软件版本
00 01字节数固定 0x0001
AD CACRC16前 6 字节数据的 CRC16 校验和

返回码:01 03 02 00 64 B9 AF

字段含义备注
01设备地址固定 0x01
0303 指令读保持寄存器
02字节数返回字节数
00 64软件版本转为十进制然后小数点左移两位即表示软件版本
0x0064 = 100 = V1.00
B9 AFCRC16前 5 字节数据的 CRC16 校验和

示例 [1 号地址设备]:

发送:01 03 80 00 00 01 AD CA
返回:01 03 02 00 C8 B9 D2 //0x00C8 = 200 =V2.00

异常功能码

当接收到的指令出错或者异常设备将会返回异常响应,异常响应格式如下。

返回码:01 85 03 02 91

字段含义备注
01设备地址0x00 表示广播地址;0x01-0xFF 表示设备地址
85异常功能码异常功能码 = 请求功能码 + 0x80
03字节数异常码
02 91CRC16前 6 字节数据的 CRC16 校验和

异常码是一个单字节值,用于指示错误的类型。Modbus 协议定义的几个常用异常码:

异常码名称描述
0x01非法功能请求的功能码不支持
0x02非法数据地址请求的数据地址错误
0x03非法数据值请求的数据值或操作无法执行
0x04服务器故障服务器设备故障
0x05应答已接收到请求并正在处理
0x06设备繁忙设备当前正忙无法执行请求的操作

Modbus TCP 指令介绍

在这里以上面打开第一个继电器的指令为例简单介绍一下 modbus tcp 与 modbus rtu 协议转换。

Modbus RTU 指令:01 05 00 00 FF 00 8C 3A

字段含义备注
01设备地址固定 0x01
0505 指令控制继电器指令
00 00地址要控制继电器的寄存器地址,0x00,即第一个继电器
FF 00指令0xFF00: 继电器开启
8C 3ACRC16前 6 字节数据的 CRC16 校验和

Modbus TCP 指令:00 00 00 00 00 06 01 05 00 00 FF 00

字段含义备注
00 00消息标号都是 0x00 即可
00 00modbus 标志号必须都为 0,代表这是 modbus 通信
00 06字节长度表示后面的所有字节数,后面还有 6 个字节
01设备地址固定 0x01
0505 指令控制继电器指令
00 00地址要控制继电器的寄存器地址,0x00,即第一个继电器
FF 00指令0xFF00: 继电器开启

通过上面指令的对比可以发现,modbus rtu 指令去掉 CRC 校验,前面加上五个 0x00 和一个字节长度即可转为 modbus tcp 协议。

比如服务器网口收到 00 00 00 00 00 06 01 05 00 00 FF 00 的 Modbus TCP 指令(打开第一个继电器),则主控收到 01 05 00 00 FF 00 8C 3A 的 Modbus RTU 指令。