由于感觉上一次写的篇幅过长,所以新开一贴,继续介绍Modbus TCP/IP的初步认识,

书接上回

3)、03(0x03)功能码--------读保持寄存器

请求与响应格式

这是一个请求读寄存器108-110 的实例:

发送数据为:

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x03, 0x00, 0x6B, 0x00, 0x03

程序如下:
[csharp] view plain copy
  1. private void send03_Click(object sender, EventArgs e)
  2. {
  3. byte[] data = new byte[] { 0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x03, 0x00, 0x6C, 0x00, 0x03 };
  4. newclient.Send(data);
  5. }


接收数据为:

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x03, 0x06, 0x02, 0x2B, 0x00,0x00,0x00,0x64

程序如下:

[csharp] view plain copy
  1. public void showMsg03(string msg)
  2. {
  3. //在线程里以安全方式调用控件
  4. if (receive0x01.InvokeRequired)
  5. {
  6. MyInvoke _myinvoke = new MyInvoke(showMsg03);
  7. receive0x03.Invoke(_myinvoke, new object[] { msg });
  8. }
  9. else
  10. {
  11. receive0x03.AppendText(msg);
  12. }
  13. }

我们再来看一下Modbus Slave设置







我们再看一下Wireshark截取封包

Modbus TCP请求



Modbus TCP响应



我们的软件所收到的数据




4)、05(0x05)功能码--------写单个线圈
 
十六进制值0XFF00请求线圈为ON。十六进制值0X0000请求线圈为OFF。

其它所有值均为非法的,并且对线圈不起作用。

请求与应答PDU


这是一个请求写线圈173 为ON 的实例:




发送数据为;

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x05, 0x00, 0xAD, 0xFF, 0x00

程序如下:

[csharp] view plain copy
  1. private void send05_Click(object sender, EventArgs e)
  2. {
  3. byte[] data = new byte[] { 0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x05, 0x00, 0xAD, 0xFF, 0x00 };
  4. newclient.Send(data);
  5. }

接收数据为:

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x02, 0x03,0xAD, 0xFF, 0x00

程序如下:

[csharp] view plain copy
  1. public void showMsg05(string msg)
  2. {
  3. //在线程里以安全方式调用控件
  4. if (receive0x05.InvokeRequired)
  5. {
  6. MyInvoke _myinvoke = new MyInvoke(showMsg05);
  7. receive0x05.Invoke(_myinvoke, new object[] { msg });
  8. }
  9. else
  10. {
  11. receive0x05.AppendText(msg);
  12. }
  13. }

我们再来看一下Modbus Slave设置






我们再看一下Wireshark截取封包

Modbus TCP请求



Modbus TCP响应



我们的软件所收到的数据




5)、06 (0x06)写单个寄存器

请求与应答PDU

这是一个请求将十六进制00 03 写入寄存器2的实例:

发送数据为;

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x06, 0x00, 0x01, 0x00, 0x03

程序如下:

[csharp] view plain copy
  1. private void send06_Click(object sender, EventArgs e)
  2. {
  3. byte[] data = new byte[] { 0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x06, 0x00, 0x01, 0x00, 0x03 };
  4. newclient.Send(data);
  5. }

接收数据为:

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x06, 0x00,0x01, 0x00, 0x03

程序如下:

[csharp] view plain copy
  1. <span style="font-size:14px;">public void showMsg06(string msg)
  2. {
  3. //在线程里以安全方式调用控件
  4. if (receive0x06.InvokeRequired)
  5. {
  6. MyInvoke _myinvoke = new MyInvoke(showMsg06);
  7. receive0x06.Invoke(_myinvoke, new object[] { msg });
  8. }
  9. else
  10. {
  11. receive0x06.AppendText(msg);
  12. }
  13. }</span>

我们再来看一下Modbus Slave设置







我们再看一下Wireshark截取封包

Modbus TCP请求



Modbus TCP响应




6)、15 (0x0F) 写多个线圈

在一个远程设备中,使用该功能码强制线圈序列中的每个线圈为ON 或OFF。

域比特位置中的逻辑“1”请求相应输出为ON。

域比特位置中的逻辑“0”请求相应输出为OFF。

请求与应答PDU

这是一个请求从线圈20 开始写入10 个线圈的实例:

发送数据为;

0x00, 0x01, 0x00, 0x00, 0x00, 0x09, 0x01, 0x0F, 0x00, 0x14, 0x00, 0x0A,0x02,0xCD,0x01

程序如下:

[csharp] view plain copy
  1. <span style="font-size:14px;">private void send0F_Click(object sender, EventArgs e)</span>
[csharp] view plain copy
  1. <span style="font-size:14px;">{
  2. byte[] data = new byte[] { 0x00, 0x01, 0x00, 0x00, 0x00, 0x09, 0x01, 0x0F, 0x00, 0x14, 0x00, 0x0A, 0x02, 0xCD, 0x01 };
  3. newclient.Send(data);
  4. }</span>

接收数据为:

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x0F, 0x00,0x14,0x00, 0x0A

程序如下:

[csharp] view plain copy
  1. <span style="font-size:14px;">public void showMsg0F(string msg)
  2. {
  3. //在线程里以安全方式调用控件
  4. if (receive0x0F.InvokeRequired)
  5. {
  6. MyInvoke _myinvoke = new MyInvoke(showMsg0F);
  7. receive0x0F.Invoke(_myinvoke, new object[] { msg });
  8. }
  9. else
  10. {
  11. receive0x0F.AppendText(msg);
  12. }
  13. }</span>

我们再来看一下Modbus Slave设置

我们再看一下Wireshark截取封包

Modbus TCP请求

Modbus TCP响应

我们的软件所收到的数据

7)、16 (0x10)写多个寄存器

请求与应答PDU

这是一个请求将十六进制00 0A 和01 02 写入以2 开始的两个寄存器的实例:

发送数据为;

0x00, 0x01, 0x00, 0x00, 0x00, 0x0B, 0x01, 0x010, 0x00, 0x02, 0x00, 0x02, 0x04,0x00,0x0A,0x01,0x02

程序如下:

[csharp] view plain copy
  1. <span style="font-size:14px;">private void send10_Click(object sender, EventArgs e)
  2. {
  3. byte[] data = new byte[] { 0x00, 0x01, 0x00, 0x00, 0x00, 0x0B, 0x01, 0x10, 0x00, 0x02, 0x00, 0x02, 0x04, 0x00,0x0A,0x01, 0x02 };
  4. newclient.Send(data);
  5. }</span>

接收数据为:

0x00, 0x01, 0x00, 0x00, 0x00, 0x06, 0x01, 0x10, 0x00,0x02, 0x00, 0x02

程序如下:

[csharp] view plain copy
  1. public void showMsg10(string msg)
  2. {
  3. //在线程里以安全方式调用控件
  4. if (receive0x10.InvokeRequired)
  5. {
  6. MyInvoke _myinvoke = new MyInvoke(showMsg10);
  7. receive0x10.Invoke(_myinvoke, new object[] { msg });
  8. }
  9. else
  10. {
  11. receive0x10.AppendText(msg);
  12. }
  13. }

我们再来看一下Modbus Slave设置



我们再看一下Wireshark截取封包

Modbus TCP请求


Modbus TCP响应



我们的软件所收到的数据




至此,我们对Modbus协议的初步认识就到此结束了,这里我们只做了对Modbus TCP

客户端的了解,之后的博文中我会陆续增加Modbus TCP服务器,modbus 485协议的

主从站,还有在硬件上如何实现modbus通讯等一系列内容敬请关注,同时,由于本人

也是出于学习目的,希望博文中有任何不足的地方都请大家提出,我也学习改正。


初识Modbus TCP/IP-------------C#编写Modbus TCP客户端程序(二)的更多相关文章

  1. 计算机网络通信TCP/IP协议浅析 网络发展简介(二)

    本文对计算机网络通信的原理进行简单的介绍 首先从网络协议分层的概念进行介绍,然后对TCP.IP协议族进行了概念讲解,然后对操作系统关于通信抽象模型进行了简单介绍,最后简单描述了socket   分层的 ...

  2. TCP/IP源码(59)——TCP中的三个接收队列

    http://blog.chinaunix.net/uid-23629988-id-3482647.html TCP/IP源码(59)——TCP中的三个接收队列  作者:gfree.wind@gmai ...

  3. TCP/IP协议族之链路层(二)

    TCP/IP学习记录,如有错误请指正,谢谢!!! TCP/IP协议族之链路层(二) 链路层是最底层协议,主要有三个目的: 1. 为IP模块发送和接收IP数据报 2. 为ARP模块发送ARP请求和接收A ...

  4. 图解 TCP/IP 第六章 TCP与UDP 笔记6.1 传输层的作用

     图解 TCP/IP  第六章 TCP与UDP   笔记6.1 传输层的作用   传输层必须指出这个具体的程序,为了实现这一功能,使用端口号这样一种识别码.根据端口号,就可以识别在传输层上一层的应用程 ...

  5. TCP/IP解析(一):TCP/IP的工作方式

    本文包括下面内容: 1.TCP/IP协议系统 2.OSI模型 3.数据包 4.TCP/IP的交互方式 1.TCP/IP模型的协议层 分为四层: 网络訪问层:提供与物理网络连接的接口.依据硬件的物理地址 ...

  6. linux tcp/ip编程和windows tcp/ip编程差别以及windows socket编程详解

    最近要涉及对接现有应用visual c++开发的tcp客户端,花时间了解了下windows下tcp开发和linux的差别,从开发的角度而言,最大的差别是头文件(早期为了推广尽可能兼容,后面越来越扩展, ...

  7. TCP/IP学习笔记:TCP传输控制协议(一)

    1 TCP的服务 尽管TCP和UDP都使用相同的网络层(IP),TCP却向用户提供一种面向连接的,可靠地字节流服务.两个使用TCP的应用,在彼此交换数据之前必须先建立一个TCP连接,在一个TCP连接中 ...

  8. -1-7 java 网络编程基本知识点 计算机网络 TCP/IP协议栈 通信必备 tcp udp

    计算机网络 是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来, 在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统. 网络编程 ...

  9. TCP/IP知识总结(TCP/IP协议族读书笔记二)

    接下来,总结一下网络层的协议,IP,ARP,RARP,ICMP,IGMP.当我们在网络传输的过程中,把分组交付到主机或路由器需要两级地址:物理地址和逻辑地址.而且我们需要能够把物理地址映射成为相应的逻 ...

随机推荐

  1. etcd:从应用场景到实现原理的全方位解读

    随着CoreOS和Kubernetes等项目在开源社区日益火热,它们项目中都用到的etcd组件作为一个高可用强一致性的服务发现存储仓库,渐 渐为开发人员所关注.在云计算时代,如何让服务快速透明地接入到 ...

  2. vue axios跨域请求,apache服务器设置

    问题所在axios请求会发送两次请求 也就是说,它会先使用options去测试,你这个接口是否能够正常通讯,如果不能就不会发送真正的请求过来,如果测试通讯正常,则开始正常请求. 思路: 跨域--> ...

  3. 解决safari中iframe嵌入不能滚动的问题

    做完了个webapp之后,开发的时候一直在浏览器上模拟ios,没有任何问题,谁知交差的时候,客户告知在ios浏览器中不能滚动嵌入的iframe,直接就滚动外层整个document了,你知道docume ...

  4. 标准库Queue的实现

    跟上篇实现stack的思路一致,我增加了一些成员函数模板,支持不同类型的Queue之间的复制和赋值. 同时提供一个异常类. 代码如下: #ifndef QUEUE_HPP #define QUEUE_ ...

  5. python——操作符重载(重要)

    类可以重载python的操作符   旧认识:__X__的名字 是系统定义的名字:是python特殊方法专用标识.   操作符重载使我们的对象与内置的一样.__X__的名字的方法是特殊的挂钩(hook) ...

  6. MySql修改root密码、设置IP访问

    先登录:mysql -h 192.168.5.116 -P 3306 -u root -p123456 首次登陆无密码命令:mysql -h 192.168.5.116 -P 3306 -u root ...

  7. boost库常用功能

    1.shared_ptr shared_ptr除了最基本的可以用new初始化以外,还可以使用其他方式初始化.在使用一些c的api时候,这种初始化方式非常有用,如下 boost::shared_ptr& ...

  8. .Net 异步调用

    .NET异步编程之新利器——Task与Await.Async   一.  FrameWork 4.0之前的线程世界    在.NET FrameWork 4.0之前,如果我们使用线程.一般有以下几种方 ...

  9. 关于javaSocket中 Software caused connection abort: recv failed问题

    在学习Socket中今天突然遇到了以下这种问题 原来是网路连接出了问题,由于我測试的是远程连接所以是在学校的局域网下,结果非常不稳定,開始还以为怎么了一会连上了一会又出现故障然后把IP地址改为本机的1 ...

  10. 解决Linux上解压jdk报错gzip: stdin: not in gzip format

    最近在阿里上买了个服务器玩,需要安装jdk,在解压过程中遇到了一些问题,又是一番Google度娘,终于解决了.问题原因让我有点无奈…… 输入 #tar -xvf jdk-8u131-linux-x64 ...