【傻瓜级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执行案例

目录
相关文章
|
27天前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
40 5
|
29天前
|
JSON 前端开发 JavaScript
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
35 4
|
28天前
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
1月前
|
设计模式 前端开发 JavaScript
揭秘!前端大牛们如何巧妙利用JavaScript,打造智能交互体验!
【10月更文挑战第30天】前端开发领域充满了无限可能与创意,JavaScript作为核心语言,凭借强大的功能和灵活性,成为打造智能交互体验的重要工具。本文介绍前端大牛如何利用JavaScript实现平滑滚动、复杂动画、实时数据更新和智能表单验证等效果,展示了JavaScript的多样性和强大能力。
51 4
|
2月前
|
存储 JavaScript 前端开发
【JavaScript】网页交互的灵魂舞者
本文介绍了 JavaScript 的三种引入方式(行内、内部、外部)和基础语法,包括变量、数据类型、运算符、数组、函数和对象等内容。同时,文章还详细讲解了 jQuery 的基本语法和常用方法,如 `text()`、`html()`、`val()`、`attr()` 和 `css()` 等,以及如何插入和删除元素。通过示例代码和图解,帮助读者更好地理解和应用这些知识。
29 1
【JavaScript】网页交互的灵魂舞者
|
1月前
|
数据采集 存储 JavaScript
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
本文介绍了如何使用Puppeteer和Node.js爬取大学招生数据,并通过代理IP提升爬取的稳定性和效率。Puppeteer作为一个强大的Node.js库,能够模拟真实浏览器访问,支持JavaScript渲染,适合复杂的爬取任务。文章详细讲解了安装Puppeteer、配置代理IP、实现爬虫代码的步骤,并提供了代码示例。此外,还给出了注意事项和优化建议,帮助读者高效地抓取和分析招生数据。
如何使用Puppeteer和Node.js爬取大学招生数据:入门指南
|
2月前
|
JavaScript 数据安全/隐私保护
2024了,你会使用原生js批量获取表单数据吗
2024了,你会使用原生js批量获取表单数据吗
57 4
|
移动开发 JavaScript Android开发