工控安全入门分析

摘要:
安全行业仍然很敏感。本文从科普的角度对工业控制安全进行了介绍性分析。丹尼尔绕过它,不喜欢轻喷。ICCP电力控制中心通信协议。action=search&description=scada&e_ Author=0x03 Uyun工业控制漏洞分析工业控制相关漏洞关键字搜索Uyun主站的漏洞:工业控制、scada、Modbus、PLC和进一步集成,以获得以下列表。工业控制本质漏洞分析以下七个与黑云工业控制相关的本质漏洞在想法的亮点中进行了分析,这可能也是获得雷霆本质的原因。几乎相同的是相应的工业控制系统的控制。

转载(http://bobao.360.cn/learning/detail/659.html)

0x00写在前面


工业4.0,物联网趋势化,工控安全实战化。安全从业保持敏感,本篇以科普角度对工控安全做入门分析,大牛绕过,不喜轻喷。

工控安全入门分析第1张

0x01专业术语


SCADA:数据采集与监视控制系统

ICS:工业控制系统

DCS:分布式控制系统/集散控制系统

PCS:过程控制系统

ESD:应急停车系统

PLC:可编程序控制器(Programmable Logic Controller)

RTU:远程终端控制系统

IED:智能监测单元

HMI:人机界面(Human Machine Interface)

MIS:管理信息系统(Management Information System)

SIS: 生产过程自动化监控和管理系统(Supervisory Information System)

MES:制造执行管理系统

0x02协议端口及测试脚本


协议科普

Modbus

MODBUS协议定义了一个与基础通信层无关的简单协议数据单元(PDU)。特定总线或网络上的MODBUS协议映射能够在应用数据单元(ADU)上引入一些附加域。

工控安全入门分析第2张

安全问题:

缺乏认证:仅需要使用一个合法的Modbus地址和合法的功能码即可以建立一个Modbus会话

缺乏授权:没有基于角色的访问控制机制, 任意用户可以执行任意的功能。

缺乏加密:地址和命令明文传输, 可以很容易地捕获和解析

PROFIBUS

一种用于工厂自动化车间级监控和现场设备层数据通信与控制的现场总线技术,可实现现场设备层到车间级监控的分散式数字控制和现场通信网络

DNP3

DNP(Distributed Network Protocol,分布式网络协议)是一种应用于自动化组件之间的通讯协议,常见于电力、水处理等行业。

简化OSI模型,只包含了物理层,数据层与应用层的体系结构(EPA)。

SCADA可以使用DNP协议与主站、RTU、及IED进行通讯。

ICCP

电力控制中心通讯协议。

OPC

过程控制的OLE (OLE for Process Control)。

OPC包括一整套接口、属性和方法的标准集,用于过程控制和制造业自动化系统。

BACnet

楼宇自动控制网络数据通讯协议(A Data Communication Protocol for Building Automation and Control Networks)。

BACnet 协议是为计算机控制采暖、制冷、空调HVAC系统和其他建筑物设备系统定义服务和协议

CIP

通用工业协议,被deviceNet、ControINet、EtherNet/IP三种网络所采用。

Siemens S7

属于第7层的协议,用于西门子设备之间进行交换数据,通过TSAP,可加载MPI,DP,以太网等不同物理结构总线或网络上,PLC一般可以通过封装好的通讯功能块实现。

其他工控协议

IEC 60870-5-104、EtherNet/IP、Tridium Niagara Fox、Crimson V3、OMRON FINS、PCWorx、ProConOs、MELSEC-Q。按需求自行查阅资料。

信息探测

协议测试脚本

工控安全入门分析第3张

PS:简要测试,大量脚本自行测试。

相关搜索引擎

Shodan搜索

工控安全入门分析第4张

PS:Shodan搜索引擎介绍 http://drops.wooyun.org/tips/2469

Zoomeye搜索

工控安全入门分析第5张

PS:敏感信息,你懂得。

Ethernet/IP 44818

1
nmap -p 44818 --script enip-enumerate.nse 85.132.179.*

工控安全入门分析第6张

Modbus 502

1
nmap --script modicon-info.nse -Pn -p 502 -sV 91.83.43.*

工控安全入门分析第7张

IEC 61870-5-101/104 2404

1
nmap -Pn -n -d --script iec-identify.nse --script-args=iec-identify -p 2404 80.34.253.*

工控安全入门分析第8张

Siemens S7 102

1
nmap -p 102 --script s7-enumerate -sV 140.207.152.*

工控安全入门分析第9张

1
nmap -d --script mms-identify.nse --script-args='mms-identify.timeout=500' -p 102 IP

工控安全入门分析第10张

Tridium Niagara Fox 1911

1
nmap -p 1911 --script fox-info 99.55.238.*

工控安全入门分析第11张

意义何在

上述NSE脚本意义:

定位工控系统及协议模块。

收集目标工控的信息,如版本、内网IP、模块、硬件信息等。

结合对应的NSE脚本进一步拓展,例如自定义空间搜素引擎。

脚本资源

Github测试脚本

https://github.com/atimorin/scada-tools 

https://github.com/atimorin/PoC2013 

https://github.com/drainware/scada-tools 

https://github.com/drainware/nmap-scada

Exploit-db测试脚本

https://www.exploit-db.com/exploits/19833/ 

https://www.exploit-db.com/exploits/19832/ 

https://www.exploit-db.com/exploits/19831/ 

https://www.exploit-db.com/search/?action=search&description=scada&e_author=

0x03乌云工控漏洞的分析


工控相关漏洞分析

针对乌云主站的漏洞进行关键字搜索:工控(31)、SCADA(15)、Modbus(9)、PLC并进一步整合得到如下列表。

工控安全入门分析第12张

工控安全入门分析第13张

在以上的漏洞列表中,可以得出如下结论:

乌云工控漏洞的案例中,绝大多起因是弱口令(弱口令最多的是123456,其次是admin)、注入类漏洞。

能够挖出工控的精华漏洞的人也是特定的那几位,且在Kcon2015也有过演讲。

挖掘此类漏洞主要解决两个问题

如何找到工控相关的系统和地址

Getshell后,基于工控知识如何操控系统

根据漏洞中的细节可以进一步的复测和拓展,进而为工控系统的漏洞挖掘提供非线性思路。

结合GHDB关键字的搜素:例如inurl:SCADA……

链接地址含SCADA、Modbus等协议的关键字……

其他KEY:MIS、SIS、DCS、PLC、ICS、监控系统……

相关公司:南京科远、金风科技、天能集团、国电南瑞、华润燃气、积成电子、重庆三峰、东方电子……

至于利用以上四点去做什么,呵呵…

工控精华漏洞分析

乌云工控相关的精华漏洞如下7个,在思路亮点中分析了漏洞的核心,同样也可能是获得打雷精华的理由。几乎共同点均是操控了对应的工控系统。

工控安全入门分析第14张

0x04参考资源


工控专题

ZoomEye工控专题: http://ics.zoomeye.org/

Shodan工控专题:https://www.shodan.io/report/l7VjfVKc

牛人分享

Z-0ne专注于工控安全攻防技术研究 :http://plcscan.org/blog/

网络空间工控设备的发现与入侵:https://github.com/evilcos/papers

工控安全攻防演练场景实现分享(轨道交通):http://zone.wooyun.org/content/14428

工业网络渗透,直击工控安全的罩门(zph,暂无资料)

工控系统安全威胁与应对探索(Kimon)

Exploit PLC on the internet(Z-0ne):https://github.com/knownsec/KCon/tree/master/KCon%202015

其他参考

Google & baidu

协议安全分析专业公司——科诺康:http://www.codenomicon.com/cn/

Modbus通讯协议学习 - 认识篇:http://www.cnblogs.com/luomingui/archive/2013/06/14/Modbus.html

免责声明:文章转载自《工控安全入门分析》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇SAP GUI安装出现ocx错误提示的解决办法Java(多)线程中注入Spring的Bean下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

在阿里云创建子域名,配置nginx,使用pm2部署node项目到ubuntu服务器

配置域名 在阿里云找到主域名   进入主域名之后,右上角添加解析,添加子域名, 记录类型选择cname,主机记录填写子域名的名称,记录值为主域名,至此阿里云已经配置好了。 检查nginx安装 首先检查服务器是否安装nginx:   find / -name 'nginx.conf'  -ls   或者   ps -ef|grep nginx   安装ng...

SSL相关漏洞解决方法

最近用绿盟扫描系统进行内网网系统扫描,有几台设备被扫出了SSL相关漏洞,在此做一个简短的加固方法。 本次涉及漏洞 1.漏洞名称:SSL 3.0 POODLE攻击信息泄露漏洞(CVE-2014-3566)【原理扫描】 2.SSL/TLS 受诫礼(BAR-MITZVAH)攻击漏洞(CVE-2015-2808)【原理扫描】 知识普及1:SSL协议要点 SSL(S...

远程获取--snmp模块(python)/snmp-cmds,easysnmp

一、简介 snmp-cmds模块通过SNMP与目标设备进行通信,此模块适用于windows,此模块是基于系统已安装了net-snmp环境easysnmp模块通过SNMP与谬表设备进行通信,此模块用于linux,此模块基于系统已安装了net-snmp环境 二、snmp-cmds模块安装 2.1 在Windows平台 #1.系统环境安装net-snmp软件...

Xamarin.Android Binding 源自github第三方库的绑定(初级教学)aar文件

好记性不如烂笔头,所以就有了这篇文章.  先来个简单的Android第三方库的绑定,就是不依赖别的库的库,build时不会出现error的那种  所以我找了一个超级简单的第三方库----Loading,github地址:https://github.com/open-android/Loading 效果图: 1. vs2017安装  Xamarin.Gra...

生产环境 压测

spring boot下Servlet容器Tomcat和Undertow性能对比 - shog808的博客 - CSDN博客https://blog.csdn.net/shog808/article/details/79162871 基于Dubbo的压测调优实例 - 简书https://www.jianshu.com/p/69398d2bdf2e 记一次生...

IntelliJ IDEA之常用插件安装及介绍

进入插件安装界面下载相应插件 1)、辅助阅读:Translation(翻译插件,支持谷歌、有道、百度翻译),CodeGlance(在编辑区的右侧显示代码图的插件),Code Search(问题搜索,支持百度、谷歌等) 2)、代码规范与质量检测:FindBugs、PMD、CheckStyle(但是本人偏爱Alibaba Java Coding Gui...