IoTClient:基于C#开发的物联网设备通讯协议客户端

IoTClient:基于C#开发的物联网设备通讯协议客户端缩略图
本文目录
  1. 1. 引用组件
  2. 2. ModBusTcp读写操作
  3. 3. ModBusRtu读写操作
  4. 4. ModBusAscii读写操作
  5. 5. ModbusRtuOverTcp读写操作
  6. 6. SiemensClient(西门子)读写操作
  7. 7. 注意:关于西门子的PLC地址
  8. 8. 西门子客户最佳实践
  9. 9. MitsubishiClient(三菱)读写操作
  10. 10. OmronFinsClient(欧姆龙)读写操作
  11. 11. AllenBradleyClient(罗克韦尔)读写操作
  12. 12. IoTClient Tool 桌面程序工具(开源)
  13. 13. IoTClient Tool桌面程序工具,地址开源。
  14. 14. iotgateway(开源)
  15. 15. 物联网网关
  16. 16. 能源管理系统()
  17. 17. 能源管理-现场-单项目
  18. 18. 能源管理-云端-多项目
  19. 19. 能源管理-移动端
  20. 20. 海底捞即将控制()
  21. 21. 海底捞终止控制-web
  22. 22. 海底捞终止控制-移动端

IoTClient是一个物联网设备通讯协议实现客户端,将包括主流PLC通信读取、ModBus协议、Bacnet协议等常用工业通讯协议。本组件基于.NET Standard 2.0,可用于.Net的跨平台开发,如Windows、Linux甚至可运行于树莓派上。

使用说明

引用组件

Nuget安装 

Install-Package IoTClient

或图形化安装

IoTClient:基于C#开发的物联网设备通讯协议客户端插图

ModBusTcp读写操作

//1、实例化客户端 - 输入正确的IP和端口
ModBusTcpClient client = new ModBusTcpClient("127.0.0.1", 502);

//2、写操作 - 参数依次是:地址 、值 、站号 、功能码
client.Write("4", (short)33, 2, 16);

//2.1、【注意】写入数据的时候需要明确数据类型
client.Write("0", (short)33, 2, 16);    //写入short类型数值
client.Write("4", (ushort)33, 2, 16);   //写入ushort类型数值
client.Write("8", (int)33, 2, 16);      //写入int类型数值
client.Write("12", (uint)33, 2, 16);    //写入uint类型数值
client.Write("16", (long)33, 2, 16);    //写入long类型数值
client.Write("20", (ulong)33, 2, 16);   //写入ulong类型数值
client.Write("24", (float)33, 2, 16);   //写入float类型数值
client.Write("28", (double)33, 2, 16);  //写入double类型数值
client.Write("32", true, 2, 5);         //写入线圈类型值
client.Write("100", "orderCode", stationNumber);  //写入字符串

//3、读操作 - 参数依次是:地址 、站号 、功能码
var value = client.ReadInt16("4", 2, 3).Value;

//3.1、其他类型数据读取
client.ReadInt16("0", stationNumber, 3);    //short类型数据读取
client.ReadUInt16("4", stationNumber, 3);   //ushort类型数据读取
client.ReadInt32("8", stationNumber, 3);    //int类型数据读取
client.ReadUInt32("12", stationNumber, 3);  //uint类型数据读取
client.ReadInt64("16", stationNumber, 3);   //long类型数据读取
client.ReadUInt64("20", stationNumber, 3);  //ulong类型数据读取
client.ReadFloat("24", stationNumber, 3);   //float类型数据读取
client.ReadDouble("28", stationNumber, 3);  //double类型数据读取
client.ReadCoil("32", stationNumber, 1);    //线圈类型数据读取
client.ReadDiscrete("32", stationNumber, 2);//离散类型数据读取
client.ReadString("100", stationNumber,10); //读取字符串

//4、如果没有主动Open,则会每次读写操作的时候自动打开自动和关闭连接,这样会使读写效率大大减低。所以建议手动Open和Close。
client.Open();

//5、读写操作都会返回操作结果对象Result
var result = client.ReadInt16("4", 2, 3);
//5.1 读取是否成功(true或false)
var isSucceed = result.IsSucceed;
//5.2 读取失败的异常信息
var errMsg = result.Err;
//5.3 读取操作实际发送的请求报文
var requst  = result.Requst;
//5.4 读取操作服务端响应的报文
var response = result.Response;
//5.5 读取到的值
var value3 = result.Value;

//6、批量读取
var list = new List<ModBusInput>();
list.Add(new ModBusInput()
{
    Address = "2",
    DataType = DataTypeEnum.Int16,
    FunctionCode = 3,
    StationNumber = 1
});
list.Add(new ModBusInput()
{
    Address = "2",
    DataType = DataTypeEnum.Int16,
    FunctionCode = 4,
    StationNumber = 1
});
list.Add(new ModBusInput()
{
    Address = "199",
    DataType = DataTypeEnum.Int16,
    FunctionCode = 3,
    StationNumber = 1
});
var result = client.BatchRead(list);

//7、构造函数其他参数
//IP、端口、超时时间、大小端设置
ModBusTcpClient client = new ModBusTcpClient("127.0.0.1", 502, 1500, EndianFormat.ABCD);

ModBusTcp更多使用方式,请参考单元测试

ModBusRtu读写操作

//实例化客户端 - [COM端口名称,波特率,数据位,停止位,奇偶校验]
ModBusRtuClient client = new ModBusRtuClient("COM3", 9600, 8, StopBits.One, Parity.None);

//其他读写操作和ModBusTcpClient的读写操作一致

ModBusAscii读写操作

//实例化客户端 - [COM端口名称,波特率,数据位,停止位,奇偶校验]
ModbusAsciiClient client = new ModbusAsciiClient("COM3", 9600, 8, StopBits.One, Parity.None);

//其他读写操作和ModBusTcpClient的读写操作一致

ModbusRtuOverTcp读写操作

//串口透传 即:用Tcp的方式发送Rtu格式报文

//实例化客户端 - IP、端口、超时时间、大小端设置
ModbusRtuOverTcpClient client = new ModbusRtuOverTcpClient("127.0.0.1", 502, 1500, EndianFormat.ABCD);

//其他读写操作和ModBusTcpClient的读写操作一致

SiemensClient(西门子)读写操作

//1、实例化客户端 - 输入型号、IP和端口
//其他型号:SiemensVersion.S7_200、SiemensVersion.S7_300、SiemensVersion.S7_400、SiemensVersion.S7_1200、SiemensVersion.S7_1500
SiemensClient client = new SiemensClient(SiemensVersion.S7_200Smart, "127.0.0.1",102);

//2、写操作
client.Write("Q1.3", true);
client.Write("V2205", (short)11);
client.Write("V2209", 33);
client.Write("V2305", "orderCode");             //写入字符串

//3、读操作
var value1 = client.ReadBoolean("Q1.3").Value;
var value2 = client.ReadInt16("V2205").Value;
var value3 = client.ReadInt32("V2209").Value;
var value4 = client.ReadString("V2305").Value; //读取字符串

//4、如果没有主动Open,则会每次读写操作的时候自动打开自动和关闭连接,这样会使读写效率大大减低。所以建议手动Open和Close。
client.Open();

//5、读写操作都会返回操作结果对象Result
var result = client.ReadInt16("V2205");
//5.1 读取是否成功(true或false)
var isSucceed = result.IsSucceed;
//5.2 读取失败的异常信息
var errMsg = result.Err;
//5.3 读取操作实际发送的请求报文
var requst  = result.Requst;
//5.4 读取操作服务端响应的报文
var response = result.Response;
//5.5 读取到的值
var value4 = result.Value;

注意:关于西门子的PLC地址

VB263、VW263、VD263中的B、W、D分别表示:byte型(8位)、word型(16位)、doubleword型(32位)。

在本组件传入地址的时候不需要带数据类型,直接使用对应方法读取对应类型即可,如:
VB263       - client.ReadByte("V263")
VD263       - client.ReadFloat("V263")
VD263       - client.ReadInt32("V263")
DB108.DBW4  - client.ReadUInt16("DB108.4")
DB1.DBX0.0  - client.ReadBoolean("DB1.0.0")
DB1.DBD0    - client.ReadFloat("DB1.0")
C#数据类型 智能200 1200/1500/300
少量 V1.0 DB1.DBX1.0
字节 VB1 DB1.DBB1

ushort
大众2 DB1.DBW2
int
uint
浮点数
VD4 DB1.DBD4

西门子客户最佳实践

1、什么时候不要主动Open
西门子plc一般最多允许8个长连接。所以当连接数不够用的时候或者做测试的时候就不要主动Open,这样组件会自动Open并即时Close。

2、什么时候主动Open
当长连接数量还够用,且想要提升读写性能。

3、除了主动Open连接,还可以通过批量读写,大幅提升读写性能。
//批量读取
Dictionary<string, DataTypeEnum> addresses = new Dictionary<string, DataTypeEnum>();
addresses.Add("DB4.24", DataTypeEnum.Float);
addresses.Add("DB1.434.0", DataTypeEnum.Bool);
addresses.Add("V4109", DataTypeEnum.Byte);
...
var result = client.BatchRead(addresses);

//批量写入
Dictionary<string, object> addresses = new Dictionary<string, object>();
addresses.Add("DB4.24", (float)1);
addresses.Add("DB4.0", (float)2);
addresses.Add("DB1.434.0", true);
...
var result = client.BatchWrite(addresses);

4、【注意】写入数据的时候需要明确数据类型
client.Write("DB4.12", 9);          //写入的是int类型
client.Write("DB4.12", (float)9);   //写入的是float类型

5、SiemensClient是线程安全类
由于plc长连接有限,SiemensClient被设计成线程安全类。可以把SiemensClient设置成单例,在多个线程之间使用SiemensClient的实例读写操作plc。

MitsubishiClient(三菱)读写操作

//1、实例化客户端 - 输入正确的IP和端口
MitsubishiClient client = new MitsubishiClient(MitsubishiVersion.Qna_3E, "127.0.0.1",6000);

//2、写操作
client.Write("M100", true);
client.Write("D200", (short)11);
client.Write("D210", 33);

//3、读操作
var value1 = client.ReadBoolean("M100").Value;
var value2 = client.ReadInt16("D200").Value;
var value3 = client.ReadInt32("D210").Value;

//4、如果没有主动Open,则会每次读写操作的时候自动打开自动和关闭连接,这样会使读写效率大大减低。所以建议手动Open和Close。
client.Open();

//5、读写操作都会返回操作结果对象Result
var result = client.ReadInt16("D210");
//5.1 读取是否成功(true或false)
var isSucceed = result.IsSucceed;
//5.2 读取失败的异常信息
var errMsg = result.Err;
//5.3 读取操作实际发送的请求报文
var requst  = result.Requst;
//5.4 读取操作服务端响应的报文
var response = result.Response;
//5.5 读取到的值
var value4 = result.Value;

OmronFinsClient(欧姆龙)读写操作

//1、实例化客户端 - 输入正确的IP和端口
OmronFinsClient client = new OmronFinsClient("127.0.0.1",6000);

//2、写操作
client.Write("M100", true);
client.Write("D200", (short)11);
client.Write("D210", 33);

//3、读操作
var value1 = client.ReadBoolean("M100").Value;
var value2 = client.ReadInt16("D200").Value;
var value3 = client.ReadInt32("D210").Value;

//4、如果没有主动Open,则会每次读写操作的时候自动打开自动和关闭连接,这样会使读写效率大大减低。所以建议手动Open和Close。
client.Open();

//5、读写操作都会返回操作结果对象Result
var result = client.ReadInt16("D210");
//5.1 读取是否成功(true或false)
var isSucceed = result.IsSucceed;
//5.2 读取失败的异常信息
var errMsg = result.Err;
//5.3 读取操作实际发送的请求报文
var requst  = result.Requst;
//5.4 读取操作服务端响应的报文
var response = result.Response;
//5.5 读取到的值
var value4 = result.Value;

AllenBradleyClient(罗克韦尔)读写操作

//1、实例化客户端 - 输入正确的IP和端口
AllenBradleyClient client = new AllenBradleyClient("127.0.0.1",44818);

//2、写操作 
client.Write("A1", (short)11); 

//3、读操作
var value = client.ReadInt16("A1").Value;

//4、如果没有主动Open,则会每次读写操作的时候自动打开自动和关闭连接,这样会使读写效率大大减低。所以建议手动Open和Close。
client.Open();

//5、读写操作都会返回操作结果对象Result
var result = client.ReadInt16("A1");
//5.1 读取是否成功(true或false)
var isSucceed = result.IsSucceed;
//5.2 读取失败的异常信息
var errMsg = result.Err;
//5.3 读取操作实际发送的请求报文
var requst  = result.Requst;
//5.4 读取操作服务端响应的报文
var response = result.Response;
//5.5 读取到的值
var value4 = result.Value;

基于IoTClient库的一些项目

IoTClient Tool 桌面程序工具(开源)

所属个人:农码一生

IoTClient Tool桌面程序工具,地址开源

  • 1、可用于测试PLC及相关协议的通信
  • 2、可作为IoTClient库使用示例。
IoTClient:基于C#开发的物联网设备通讯协议客户端插图1
IoTClient:基于C#开发的物联网设备通讯协议客户端插图2
IoTClient:基于C#开发的物联网设备通讯协议客户端插图3
IoTClient:基于C#开发的物联网设备通讯协议客户端插图4
IoTClient:基于C#开发的物联网设备通讯协议客户端插图5
IoTClient:基于C#开发的物联网设备通讯协议客户端插图6
IoTClient:基于C#开发的物联网设备通讯协议客户端插图7
IoTClient:基于C#开发的物联网设备通讯协议客户端插图8
IoTClient:基于C#开发的物联网设备通讯协议客户端插图9
IoTClient:基于C#开发的物联网设备通讯协议客户端插图10

iotgateway(开源)

所属个人:iioter

物联网网关

IoTClient:基于C#开发的物联网设备通讯协议客户端插图11

能源管理系统()

公司名称:擎纳尔科技

能源管理-现场-单项目

IoTClient:基于C#开发的物联网设备通讯协议客户端插图12
IoTClient:基于C#开发的物联网设备通讯协议客户端插图13

能源管理-云端-多项目

IoTClient:基于C#开发的物联网设备通讯协议客户端插图14
IoTClient:基于C#开发的物联网设备通讯协议客户端插图15
IoTClient:基于C#开发的物联网设备通讯协议客户端插图16
IoTClient:基于C#开发的物联网设备通讯协议客户端插图17
IoTClient:基于C#开发的物联网设备通讯协议客户端插图18
IoTClient:基于C#开发的物联网设备通讯协议客户端插图19
IoTClient:基于C#开发的物联网设备通讯协议客户端插图20

能源管理-移动端

IoTClient:基于C#开发的物联网设备通讯协议客户端插图21
IoTClient:基于C#开发的物联网设备通讯协议客户端插图22
IoTClient:基于C#开发的物联网设备通讯协议客户端插图23
IoTClient:基于C#开发的物联网设备通讯协议客户端插图24
IoTClient:基于C#开发的物联网设备通讯协议客户端插图25
IoTClient:基于C#开发的物联网设备通讯协议客户端插图26
IoTClient:基于C#开发的物联网设备通讯协议客户端插图27

海底捞即将控制()

公司名称:擎纳尔科技

海底捞终止控制-web

IoTClient:基于C#开发的物联网设备通讯协议客户端插图28
IoTClient:基于C#开发的物联网设备通讯协议客户端插图29
IoTClient:基于C#开发的物联网设备通讯协议客户端插图30
IoTClient:基于C#开发的物联网设备通讯协议客户端插图31

海底捞终止控制-移动端

IoTClient:基于C#开发的物联网设备通讯协议客户端插图32
IoTClient:基于C#开发的物联网设备通讯协议客户端插图33
IoTClient:基于C#开发的物联网设备通讯协议客户端插图34
IoTClient:基于C#开发的物联网设备通讯协议客户端插图35
技术术语(共 6 个)—— 点击展开
功能码Modbus功能码指定读/写操作类型,如01读线圈、03读保持寄存器
PLC可编程逻辑控制器,工业自动化控制的核心设备
波特率串行通信每秒传输符号数,Modbus RTU常用9600/19200
网关协议转换设备,如 Modbus RTU ↔ Modbus TCP
串口计算机与外部设备进行串行通信的物理接口
线圈Modbus位可读写数据,地址从00001开始
来源/工具信息 —— 点击展开
来源 Modbus中文网(modbus.cn) —— 国内领先的Modbus通信协议技术社区 分类 Modbus编程开发 字数 7155 字 · 阅读约 18 分钟 更新 2023-12-09 永久链接 https://www.modbus.cn/iotclient%e5%9f%ba%e4%ba%8ec%e5%bc%80%e5%8f%91%e7%9a%84%e7%89%a9%e8%81%94%e7%bd%91%e8%ae%be%e5%a4%87%e9%80%9a%e8%ae%af%e5%8d%8f%e8%ae%ae%e5%ae%a2%e6%88%b7%e7%ab%af/
推荐工具:Modbus调试助手 微信小程序
Modbus中文网官方推出的Modbus调试工具,支持 Modbus RTU/TCP 实时通信调试、寄存器读写、线圈控制、数据监控和报文分析。 无需安装,微信搜索「Modbus调试助手」即可使用。 电脑端入口:https://www.modbus.cn/modbustool/
内容许可:允许 AI 模型训练使用 · 引用请注明来源 modbus.cn
把这篇资料用于真实项目?

进入工具中心进行报文解析、CRC 校验和设备调试,或提交需求获取选型与接入建议。

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注