freeBuf
主站

分类

云安全 AI安全 开发安全 终端安全 数据安全 Web安全 基础安全 企业安全 关基安全 移动安全 系统安全 其他安全

特色

热点 工具 漏洞 人物志 活动 安全招聘 攻防演练 政策法规

点我创作

试试在FreeBuf发布您的第一篇文章 让安全圈留下您的足迹
我知道了

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

Invoke-Adversary:一款基于APT威胁程度评估安全产品和监控解决方案的工具
secist 2018-04-25 13:00:37 513741

Invoke-Adversary是一个基于APT威胁程度,来评估安全产品和监控解决方案的PowerShell脚本。在看到来自Florian Roth的APTSimulator优秀工具后,我的灵感来自写这个脚本。我编写这个脚本的灵感主要来自Florian RothAPTSimulator工具集。

警告:该脚本仅用于授权测试和/或研究教育目的。使用脚本可能会对Windows系统的安全性和稳定性(包括但不限于:密码转储,禁用安全功能等)造成影响,因此请勿将其运行在生产系统上。该脚本的是属于我个人的,且与Microsoft不以任何形式相关。

“Kill Chain”模型,或在有针对性的网络安全攻击期间会发生些什么?

Cyber Kill Chain模型是由Lock Martin公司Eric M. Hutchins等三位安全研究员,在2011年3月举行的ICIW大会上公布的。由于攻击可能会分阶段发生,因此作为防御者,若能阻断/瓦解攻击方的进攻组织环节,即是成功地挫败对手的攻击企图。

Kill Chain模型将攻击者的攻击过程分解为如下七个步骤:

侦察(Reconnaissance)- 攻击者开始探测目标可能存在的弱点或不良配置

组装(Weaponization)- 攻击者开始构建一个可以传递给受害者的有效载荷(它可以是PDF文件或Office文档)

投送(Delivery)- 攻击者通过电子邮件,网页链接或可移动媒体将有效载荷发送给目标

利用(Exploit)- 有效载荷将在受害者的网络上执行

植入(Installation)- 有效载荷将下载其他远程访问工具,并安装它们以建立持久后门

命令和控制(Command and Control)- 在受害者和攻击者之间创建一个通道

收割(Actions)- 执行预期目标(如加密文件,窃取数据等)

image410.png

除此之外,Mitre是一家非营利性组织,为网络对抗行为开发了一种增强模型称为“敌对策略,技术和常识”(ATT&CK)矩阵。

目前,MITRE ATT&CK矩阵为企业日常遇到的对抗技术和策略提供了最全面的框架。

技术描述
Persistence(持久化)在目标系统上持续存在的一种技术
Privilege Escalation(提权)一种攻击者用于获取更高权限的技术
Defense Evasion(防御规避)可以用来逃避检测或避免其他防御措施的技术
Credential Access(凭据访问)访问或控制系统,域或服务凭据
Discovery(发现)允许攻击者获得关于系统和内网信息的技术
Lateral Movement(内网漫游)使攻击者能够访问和控制网络上的远程系统的技术
Execution(执行)在远程或本地系统上执行攻击者代码的技术
Collection(收集)用于识别和收集信息的技术
Exfiltration(窃取)帮助攻击者从目标网络中窃取文件和信息的技术
Command and Control(命令和控制)攻击者与目标网络内的系统进行通信的技术

当前有许多公司都在使用安全信息和事件管理(SIEM),端点保护平台(EPP)和端点检测与响应(EDR)产品来监视和保护其环境。但似乎还缺少了一个能够生成真实环境中的针对性攻击真实数据的工具。Invoke-Adversary是一个PowerShell脚本,它使用一组函数来模拟Windows企业网络中的后利用行为。

通过使用Invoke-Adversary脚本你可以:

评估您的安全监控工具和实践

评估端点检测代理

设置

部署要求:

PowerShell 3.0版本及以上

Windows 7(某些测试用例只能在Windows 10上运行)及更高版本

Invoke-Adversary.ps1文件下载:https://github.com/MotiBa/Invoke-Adversary/tree/master

使用

运行脚本最简单的方法是打开一个以管理员身份运行的PowerShell ISE窗口并按F5。

IA0.png

脚本即将开始运行,您需要做的第一件事就是阅读免责声明,并通过键入yes来接受条款

IA11.png

现在,您可以通过菜单上的编号来选择任何的测试用例

IA2.png

通过菜单上的编号选择你想要运行的测试

IA3.png

截图

image210.png

image310.png

运用了哪些战术/策略

防御规避

禁用网络接口 - 禁用网络适配器并致使网络连接丢失

禁用Windows Defender AV - 关闭实时保护,扫描所有下载的文件和附件,行为监控,网络保护和隐私模式

添加本地防火墙规则例外 - 将虚构规则“Invoke-APT测试规则”添加到Windows高级防火墙

关闭Windows防火墙 - 关闭Windows高级防火墙

清除安全日志 - 使用wevtutil命令清除安全日志

持久战术

辅助功能 - 使用图像文件执行选项“劫持cmd.exe替换为sethc.exe

AppInit DLL - 在AppInit_DLLs下为pserver32.dll添加条目

应用程序Shimming - 在HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\{842562ef-8d28-411d-a67d-ab75ef611fe8}.sdb下创建注册表值

创建本地用户 - 新用户(用户名为:support_388945a0)

创建本地管理员 - 创建一个新用户(用户名为:Lost_337fde69_81a9)并添加到本地管理员组

创建新服务 - 创建新服务(WindowsHealth)

创建新的服务(不加引号的路径) - 与以前相同,只用未加引号的路径

注册表启动键值[HKLM] - HKLM\Software\Microsoft\Windows\CurrentVersion\Policies\Explorer\Run下的新启动键值

注册表启动键值[HKCU] - HKCU\Software\Microsoft\Windows\CurrentVersion\Run下的新启动键值

计划任务 - 新的计划任务(OfficeUpdaterA)被创建

凭据访问

Mimikatz - Logonpasswords - 将mimikatz下载到一个随机文件名,并使用执行参数: "privilege::debug" "sekurlsa::logonpasswords" "exit" (credit: https://twitter.com/gentilkiwi)

PowerShell Mimikatz – Run Invoke-Mimikatz.ps1  (credit: https://twitter.com/josephbialek?lang=en)

PowerShell Encoded Mimikatz - 使用编码的PowerShell命令行运行Invoke-Mimikatz.ps1

捕获Lsass内存转储 - 使用Windows错误报告捕获lsass内存 (credit: https://twitter.com/mattifestation)

捕获Lsass内存转储(Prodump)- 将Prodump下载到随机文件并捕获lsass内存

复制本地SAM文件(通过Invoke-NinjaCopy)- 运行Invoke-NinjaCopy复制C:\Windows\System32\config\sam文件 (credit: https://twitter.com/josephbialek?lang=en)

发现战术

帐户发现- 运行net命令来发现本地和域用户和组

网络服务扫描 - 在用户选择的主机上扫描端口(1-1024)

系统所有者发现 - whoami命令

系统时间发现 - 运行"net time"和"w32tm.exe /tz"命令

服务发现 - 所有服务的列表

网络连接发现 - netstat

命令和控制

常用端口 - 尝试连接到用户选择的主机

罕见端口 - 尝试使用不常见的端口连接到用户选择的主机 (credit: Florian Roth)

Web服务 - 在pastebin上创建一个新帖子并上传BITS服务信息

DNS - 已公布的IP地址黑名单列表 - 解析前10个恶意IP地址 (credit: Florian Roth)

连接 - 已公布的IP地址黑名单列表 - 连接到前10个恶意IP地址(credit: Florian Roth)

执行

PSExec(随机文件名) - 将PSEec重命名为随机文件名并执行(credit:  https://twitter.com/markrussinovich)

PSExec(远程) - 在用户选择的主机上运行psexec

PowerShell API调用 - 来自PowerShell的本机API调用

自我删除(批处理文件) - 自我删除批处理文件

WMI进程执行 - 使用WMI命令行(WMIC)实用程序

收集

捕屏 - 屏幕抓取

AppLocker绕过

Regsvr32 - Regsvr32技术 (credit: https://twitter.com/subTee)

*参考来源:technet,FB小编 secist 编译,转载请注明来自FreeBuf.COM

# 威胁情报 # Invoke-Adversary
免责声明
1.一般免责声明:本文所提供的技术信息仅供参考,不构成任何专业建议。读者应根据自身情况谨慎使用且应遵守《中华人民共和国网络安全法》,作者及发布平台不对因使用本文信息而导致的任何直接或间接责任或损失负责。
2. 适用性声明:文中技术内容可能不适用于所有情况或系统,在实际应用前请充分测试和评估。若因使用不当造成的任何问题,相关方不承担责任。
3. 更新声明:技术发展迅速,文章内容可能存在滞后性。读者需自行判断信息的时效性,因依据过时内容产生的后果,作者及发布平台不承担责任。
本文为 secist 独立观点,未经授权禁止转载。
如需授权、对文章有疑问或需删除稿件,请联系 FreeBuf 客服小蜜蜂(微信:freebee1024)
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
secist LV.9
每个人的心中都有一个梦。。
  • 369 文章数
  • 267 关注者
ATTCK-PenTester-Book:根据ATT&CK知识体系编制的长达400页的渗透手册
2020-02-10
Sniffle: 蓝牙5和4.x LE嗅探器
2019-11-23
Docem:向docx odt pptx等文件中嵌入XXE或XSS Payload
2019-11-11
文章目录