【傻瓜级JS-DLL-WINCC-PLC交互】7.​C#直连PLC并读取PLC数据

简介: 【傻瓜级JS-DLL-WINCC-PLC交互】7.​C#直连PLC并读取PLC数据

思路

JS-DLL-WINCC-PLC之间进行交互,思路,先用Visual Studio创建一个C#的DLL控件,然后这个控件里面嵌入浏览器组件,实现JS与DLL通信,然后DLL放入到WINCC里面的图形编辑器中,实现DLL与WINCC的通信。然后PLC与WINCC之间进行连接,实现WINCC与PLC之间连接,最后自己封装方法把他们串联起来。



C#直连PLC并读取PLC数据

1.首先你得知道PLC网络IP

在博途中查看到,运行的IP地址为 192.168.0.1

2.端口默认 102

3.查看机架和插槽

从下图中可以看到,机架和插槽为0,1

4.查看新建数据的变量地址

地址公式:数据模块编号 + "." + 数据类型(DBX,DBW,DBD 对应 Bool,ushort,float)+变异量

所以下面的变量数据地址为:BD3.DBX0.0

5.配置PLC权限,让他可以直接C#拥有读写权限

如果不走这一步,后面代码汇报做

Unhandled exception. S7.Net.PlcException: Received 12 bytes: '32-02-00-00-00-00-00-00-00-00-81-04', expected 19 bytes.

---> S7.Net.PlcException: Received 12 bytes: '32-02-00-00-00-00-00-00-00-00-81-04', expected 19 bytes.

设置完全权限

勾选 允许来自远程对象的PUT/GET通讯访问

然后将项目从新编译,并装载进PLC!!!!!!!!!!!!!!!!!!!!!!!!!!!

6.代码编写案例地址

https://download.csdn.net/download/qq_59747594/88580348

7.代码讲解

将项目用Visual Studio打开,demo案例在下面位置

7.1C#读取PLC的数据,需要用到 S7.Net

using S7.Net;
//引用通信,可以自行网上搜索如何安装,一堆资料
namespace ConsoleApp1
{
    internal class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Hello, World!");
            const short TestServerPort = 102;//PLC运行的端口地址
            const string TestServerIp = "192.168.0.1";//PLC运行的IP地址
            // new Plc(CpuType.S71200, PLC的IP, PLC的端口, PLC的机架, PLC的插槽);
            var plc = new Plc(CpuType.S71200, TestServerIp, TestServerPort, 0, 1);
            plc.Open();
            Console.WriteLine($"是否已连接: {plc.IsConnected}");
            // 数据变量的地址
            var addr = "DB1.DBX0.0";
            Console.WriteLine($"原始值: {plc.Read(addr)}");
            plc.Write(addr, 1);
            Console.WriteLine($"修改后: {plc.Read(addr)!}");
            Console.ReadLine();
        }
    }
}

7.2执行案例

目录
相关文章
|
5月前
|
网络协议 网络安全 API
C# 与三菱FX5U PLC通讯交互指南
C# 与三菱FX5U PLC通讯交互指南
2068 121
|
6月前
|
存储 网络协议 C#
C#实现与西门子S7-1200/1500 PLC通信
C#实现与西门子S7-1200/1500 PLC通信
|
9月前
|
Web App开发 数据采集 JavaScript
动态网页爬取:Python如何获取JS加载的数据?
动态网页爬取:Python如何获取JS加载的数据?
1425 58
|
12月前
|
JavaScript Shell C#
多种脚本批量下载 Docker 镜像:Shell、PowerShell、Node.js 和 C#
本项目提供多种脚本(Shell、PowerShell、Node.js 和 C#)用于批量下载 Docker 镜像。配置文件 `docker-images.txt` 列出需要下载的镜像及其标签。各脚本首先检查 Docker 是否安装,接着读取配置文件并逐行处理,跳过空行和注释行,提取镜像名称和标签,调用 `docker pull` 命令下载镜像,并输出下载结果。使用时需创建配置文件并运行相应脚本。C# 版本需安装 .NET 8 runtime。
907 4
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
3605 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
11月前
|
数据采集 JavaScript 前端开发
JavaScript中通过array.filter()实现数组的数据筛选、数据清洗和链式调用,JS中数组过滤器的使用详解(附实际应用代码)
用array.filter()来实现数据筛选、数据清洗和链式调用,相对于for循环更加清晰,语义化强,能显著提升代码的可读性和可维护性。博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
608 5
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
5月前
|
XML 前端开发 C#
C#编程实践:解析HTML文档并执行元素匹配
通过上述步骤,可以在C#中有效地解析HTML文档并执行元素匹配。HtmlAgilityPack提供了一个强大而灵活的工具集,可以处理各种HTML解析任务。
297 19
|
6月前
|
监控 算法 C#
C#与Halcon联合编程实现鼠标控制图像缩放、拖动及ROI绘制
C#与Halcon联合编程实现鼠标控制图像缩放、拖动及ROI绘制
1126 0