2020ICS工业安全靶场练习记录——工控协议Writeup_1


Modbus协议

image.png-40.5kB

题目给了一个WireShark的流量包,打开分析一下

搜一下关键字符串

image.png-118.6kB

没有发现特殊字符,看一下数据包大小,探测一下是否存在异常包大小,分析MODBUS协议,发现最后一条数据包大小与其他不同

image.png-81.8kB

读一下具体数据

image.png-59.8kB

获取到flag

MMS协议

image.png-29.8kB

拿到协议包之后仍然是先搜索一下关键字符

image.png-90.1kB

发现在1771数据包中出现了flag.txt,具体分析一下1771数据包

image.png-38.7kB

可以看到1771数据包执行的是MMS协议中Fileopen指令,就是打开flag.txt的文件的指令,这里需要知道MMS协议的几个文件指令

        fileopen #打开文件
        filewrite #写入
        fileread #读取内容
        fileclose #关闭文件流
        filedictionary #列取文件名

既然1771数据包执行的是fileopen执行很可能下一步执行的就是fileread或者filewrite,过滤一下数据包,着重看一下fileread的数据包

使用正则语句进行过滤

mms.confirmedServiceRequest==73

发现在1771数据包之后,1800数据包进行了fileread操作

image.png-92.2kB

着重看一下1800数据包的返回内容

image.png-89.1kB

发现在1801数据包中返回了base64存储的图片,提取出来数据进行修复



成功获取到flag

image.png-115.2kB

大工UDP协议

image.png-31.4kB

分析数据包,依旧是前两步,搜字符、看数据长度

image.png-120.6kB

发现长度可疑的几条数据,一个一个进行查看,在第733条数据中发现可疑字符串

image.png-87.9kB

取出发现为十六进制编码,转一下字符串

image.png-43kB

成功获取flag

工控蜜罐日志分析

image.png-46kB

拿到题目发现和去年ICS-2019的题目特别相似,找了一个去年的脚本,提取IP进行域名反差

image.png-215.9kB

#-*- coding:utf-8 -*-
import fileinput
import re
import os
import shutil
def readIp():#从日志中获得IP
 with open(r'honeypot.log', 'r') as f:
      for line in f.readlines():
         result2 = re.findall('[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}',line) #匹配ip正则表达式                          
         if not result2 == []:
             result = result2[0] + '\n'
         with open('ip.txt', 'a+') as w:
             w.write(result)
def setIp():#去重
 a=0
 readDir = "ip.txt"
 writeDir = "newip.txt"#new
 lines_seen = set()
 outfile = open(writeDir, "w")
 f = open(readDir, "r")
 for line in f:
   if line not in lines_seen:
     a+=1
     outfile.write(line)
     lines_seen.add(line)
 print(a)
 outfile.close()
def readDns():#域名解析
 with open(r'newip.txt', 'r') as g:
     for i in g.readlines():
         com=os.popen('nslookup %s'%i)
         comm=com.read()
         if comm.find('NXDOMAIN')==-1:
             print comm
if __name__ == '__main__':
 readIp()
 setIp()
 readDns()

image.png-278.9kB

将获取到的域名一一进行尝试,最后的flag:

flag{scan-42.security.ipip.net}

工控安全取证

image.png-32.6kB

仍然是流量分析题目,不过这次是让分析攻击行为,看一下具体的数据流

image.png-61.9kB

数据流中有大量的TCP流和ICMP流,重点先确定攻击类型是哪种协议,我们可以推测攻击类型为ping操作,导出ICMP流进行具体的分析

image.png-76.5kB

根据数据流可以看到

目的IP地址为192.168.0.99,攻击的IP地址为192.168.0.9、192.168.0.199,题目中让我们找寻第四次攻击的数据包编号,我们可以根据id值来判断数据包是否为同一次攻击

image.png-65.7kB

根据id值我们确认了第四次攻击的数据包,再通过攻击的IP地址确认具体的攻击数据包,查看编号:

image.png-52.4kB

编号即为我们所要获取的flag


发表评论

电子邮件地址不会被公开。 必填项已用*标注