齐安安小课堂 | 串口数据抓取以及串口数据模拟
off999 2024-09-27 13:56 32 浏览 0 评论
各位同学们好,好久不见!
齐安安小课堂又双叒叕开课啦~
本期来讲讲在工控现场使用的设备中
有哪些普遍存在又容易被忽视的安全隐患
只有重视每一个小细节
才能对工业安全做出更好的防护哦~
引言
在工控现场中,存在着几乎所有设备都离不开,很基础,但是也非常容易出现安全隐患的地方——串口,那么串口是什么呢?串口通信是否有风险?本次小课堂中我们将带来解答,并详细描述如何对串口进行安全攻防。
? 什么是串口?
串口全称为串行通信接口,串行接口是一种可以将接收来自CPU的并行数据字符转换为连续的串行数据流发送出去,同时可将接收的串行数据流转换为并行的数据字符供给CPU的器件。一般完成这种功能的电路,我们称为串行接口电路。
工控现场中,所拥有的大部分网络设备都具备了串口通信,甚至将串口保留为最基础的调试接口,即使没有外接串口设备,我们也可以在PCB板上找到串口接出的pin针脚或焊点。如果工控设备没有对串口进行加密读取的话,就会产生对串口进行敏感数据操作可能性。
本文将模拟硬件与串口进行通信时及串口数据传输时对数据进行抓取和分析的过程,将模拟抓取到的数据发送给下位机,以此验证不经过系统时是否可以直接通过串口发送数据到下位机。
串口的主要运用场景
串口是计算机上一种非常通用的设备通信协议。大多数计算机(不包括笔记本电脑)包含两个基于RS-232的串口。串口同时也是仪器仪表设备通用的通信协议;很多GPIB兼容的设备也带有RS-232口。同时,串口通信协议也可以用来获取远程采集设备上所产生的数据。
RS-232(ANSI/EIA-232标准)是IBM-PC及其兼容机上的串行连接标准。用途诸多,比如连接鼠标、打印机或者Modem,也可以连接工业仪器仪表。
STM32串口通信基础以及通信过程
通常PC机(或上位机)一般使用的都是RS232接口(通常为DB9封装),不能直接交叉连接。RS232接口是9针(或引脚),常常是TxD和RxD经过电平转换得到的。所以,要想使得芯片与PC机的RS232接口直接通信,需要也将芯片的输入输出端口也电平转换成rs232类型,再交叉连接。
经过电平转换后,芯片串口和rs232的电平标准是不一样的:
单片机的电平标准(TTL电平):+5V表示1,0V表示0;
Rs232的电平标准:+15/+13 V表示0,-15/-13表示1。
进行操作时使用的工具
Virtual Serial Port Driver模拟串口
友善串口调试工具,也可自己使用python包serial进行调试,示例为了操作方便使用工具。
串口数据抓取
开始监听com口数据
抓取的数据如图所示
抓取的数据如图所示
可以查看到dump view窗口中写入的数据
以aa请求开头,以ff请求结尾,中间f0818283为数据,再观察工控机器的所做出对应的操作,即可了解到该指令的含义。
串口数据通信
最后,使用友善串口调试助手发送串口数据即可
结论
在经过测试验证的情况下,可以在没有进行串口通信加密的情况下,借助上位机(一般代指PC),绕过软件权限限制,对下位机(工控设备),进行随意的修改和发送指令。
课后答疑
Q:如何对串口数据通信进行保护呢?
A:可以在接受到外设备发送过来的8个字节数据后,通过加密处理,生成16字节密钥与标签码,并将这些信息通过串口回传给外设备。如此便可防止串口被监听导致所发送的数据泄露。
Q:现代大多工控设备中会对串口进行加密保护吗?
A:比较少,因为进行这样的操作需要直接连接到机器,然而,工控现场保护较为严密,采用物理保护后,针对软件层面上的保护一般因为节省成本而忽略掉,但是此类行为并不可取。工控数据对安全性要求非常高,不做串口加密保护,的话就相当于等同于存在一个已知的威胁隐患。所以,相关工业企业需要足够重视,更好地保护工业数据的安全。
内容:二月又三年
责编:喵喵
转载请注明出处
相关推荐
- Linux 网络协议栈_linux网络协议栈
-
前言;更多学习资料(包含视频、技术学习路线图谱、文档等)后台私信《资料》免费领取技术点包含了C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,Z...
- 揭秘 BPF map 前生今世_bpfdm
-
1.前言众所周知,map可用于内核BPF程序和用户应用程序之间实现双向的数据交换,为BPF技术中的重要基础数据结构。在BPF程序中可以通过声明structbpf_map_def...
- 教你简单 提取fmpeg 视频,音频,字幕 方法
-
ffmpeg提取视频,音频,字幕方法(HowtoExtractVideo,Audio,SubtitlefromOriginalVideo?)1.提取视频(ExtractVi...
- Linux内核原理到代码详解《内核视频教程》
-
Linux内核原理-进程入门进程进程不仅仅是一段可执行程序的代码,通常进程还包括其他资源,比如打开的文件,挂起的信号,内核内部的数据结构,处理器状态,内存地址空间,或多个执行线程,存放全局变量的数据段...
- Linux C Socket UDP编程详解及实例分享
-
1、UDP网络编程主要流程UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。...
- libevent源码分析之bufferevent使用详解
-
libevent的bufferevent在event的基础上自己维护了一个buffer,这样的话,就不需要再自己管理一个buffer了。先看看structbufferevent这个结构体struct...
- 一次解决Linux内核内存泄漏实战全过程
-
什么是内存泄漏:程序向系统申请内存,使用完不需要之后,不释放内存还给系统回收,造成申请的内存被浪费.发现系统中内存使用量随着时间的流逝,消耗的越来越多,例如下图所示:接下来的排查思路是:1.监控系统中...
- 彻底搞清楚内存泄漏的原因,如何避免内存泄漏,如何定位内存泄漏
-
作为C/C++开发人员,内存泄漏是最容易遇到的问题之一,这是由C/C++语言的特性引起的。C/C++语言与其他语言不同,需要开发者去申请和释放内存,即需要开发者去管理内存,如果内存使用不当,就容易造成...
- linux网络编程常见API详解_linux网络编程视频教程
-
Linux网络编程API函数初步剖析今天我们来分析一下前几篇博文中提到的网络编程中几个核心的API,探究一下当我们调用每个API时,内核中具体做了哪些准备和初始化工作。1、socket(family...
- Linux下C++访问web—使用libcurl库调用http接口发送解析json数据
-
一、背景这两天由于一些原因研究了研究如何在客户端C++代码中调用web服务端接口,需要访问url,并传入json数据,拿到返回值,并解析。 现在的情形是远程服务端的接口参数和返回类型都是json的字符...
- 平衡感知调节:“系统如人” 视角下的架构设计与业务稳定之道
-
在今天这个到处都是数字化的时代,系统可不是一堆冷冰冰的代码。它就像一个活生生的“数字人”,没了它,业务根本转不起来。总说“技术要为业务服务”,但实际操作起来问题不少:系统怎么才能快速响应业务需求?...
- 谈谈分布式文件系统下的本地缓存_什么是分布式文件存储
-
在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memca...
- 进程间通信之信号量semaphore--linux内核剖析
-
什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有。信号量的值为正的时候,说明它空闲。所测试的线程可以锁定而使用它。若为0,说明它被占用,测试的线程要进入睡眠...
- Qt编写推流程序/支持webrtc265/从此不用再转码/打开新世界的大门
-
一、前言在推流领域,尤其是监控行业,现在主流设备基本上都是265格式的视频流,想要在网页上直接显示监控流,之前的方案是,要么转成hls,要么魔改支持265格式的flv,要么265转成264,如果要追求...
- 30 分钟搞定 SpringBoot 视频推拉流!实战避坑指南
-
30分钟搞定SpringBoot视频推拉流!实战避坑指南在音视频开发领域,SpringBoot凭借其快速开发特性,成为很多开发者实现视频推拉流功能的首选框架。但实际开发中,从环境搭建到流处理优...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)