[ATTCK] 分析攻击手法制定红队演练流程

2023-11-23 13:20

本文主要是介绍[ATTCK] 分析攻击手法制定红队演练流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

红队演练训练环境
建立靶机环境与知识库
分析三十六个 Techniques 为范例,分析攻击手法后作为红队演练的训练,可以制定一套学习 Windows 的流程与进度表:

第0步:了解 Windows 历史与文件

  • Windows 版本与 Windows 服务器版本
  • 各版本的差异与功能不同
  • 已知弱点(如 CVE )也需要注意版本

第一步:了解基本指令的操作

分析 ATT&CK® 针对 Windows 相关的 Techniques ,可以发现 APT 组织皆以 Cmd 或是 Powershell 作为攻击媒介,因此可以针对两种指令进行训练。
可以针对 ATT&CK® 所使用的指令,进行学习,作为补充指令。
cmd 命令提示字符,可参考 初学者之卷  所撰写的教学。
Powershell :可参考 微软官方文件
  • Get-Help Command-Name :取得帮助内容。
  • Get-Command  了解目前主机安装多少 cmdlet
  • Invoke-WebRequest  :送出请求,取得网页内容。
  • 尝试了解 APT 组织所使用的 PowerShell 指令

第二步:了解 Windows File System

  • Logical drives :硬盘 C
  • 默认文件夹( PerfLogs Program Files and Program Files x86 )、 Users
  • 默认文件(操作系统的代码)
了解这些预设文件夹的功能与预设档案的功能。

第三步:Windows 权限档案

权限主体分成 Users Group ,而可以设定的权限可以分成以下七个:
  • Full control :允许用户、组设置文件夹与其他人的所有权限(修改、读取、写入、执行)。
  • Modify :允许用户和群组修改、读取、写入和执行文件。
  • Read & execute :允许用户和组读取和执行文件。
  • List folders content :允许用户和群组列出文件夹内容,含子文件夹。
  • Read :仅允许用户和群组读取档案。
  • Write :允许用户和组写入指定文件夹。
  • Special permissions :特殊访问权限。
使用 icacls 检查文件权限和文件夹权限 :
  • I :从父容器继承的权限
  • F :完全控制
  • M :修改权限
  • OI :对象继承
  • IO :仅继承
  • CI :容器继承
  • RX :读取并执行
  • AD :追加子文件夹
  • WD :写入资料

第四步:Windows 身份验证

验证身份该用户的合法性。
  • 身份验证账户:本地用户账户和系统管理员账户。
登入概念
  • 认证:确认身份过程,认证 = 凭证 + 验证
  • 授权:该用户可以做什么操作与可以访问什么资源。
  • 凭证:身份证明:系统用户帐号和密码
验证阶段通过 Local Security Authority (本地安全性验证),管理本地安全性原则,进行验证。
  • 了解 Windows 验证的原理与流程
  • Windows 内建帐号与群组的关系
  • net  指令的相关应用
  • Windows 密码与哈希( NTLM

第五步:Windows 内建功能

一、 Computer Management :电脑管理
  • 工作调度器:可以指定特定条件自动执行定义与操作。
  • 事件查看器:查看 windows Log 相关事件(成功、失败登录事件与系统错误),可以将 Log 转发到 SIEM 中确认恶意动作。
  • 共享文件夹:在网络上共享可以被多个用户访问的目录或文件夹。
  • 本地用户和组:可以新增用户,可以管理群组。
  • 效能:监视设备的 CPU 使用率、内存使用率。
  • 装置管理器:硬件管理,网络接口卡、鼠标、韧体。
  • 磁盘管理:可以缩小、扩展、新增分区并格式化。
  • 服务和应用程序:可以检查系统上正在执行的服务,启动、停止、重新启动。
二、Local Security Policy:本机安全性原则
三、Disk Cleanup
四、Registry Editor
Win + R +  RegEdit
五、Registry Editor Regedit

第六步:Windows Server

了解 Windows Server 的服务器可衍生出多种功能。

第七步:Windows Log

Windows 默认路径 。 C:\Windows\System32\winevt\Logs
三种查看 Windows 事件的工具
  1. Event Viewer
  2. Wevtutil.exe
  3. Get-WinEvent
五种 Windows 纪录的事件
  • 关闭 Windows IIS HTTP Logging 的手法
C:\Windows\System32\inetsrv\appcmd.exe set config “website_name” /section:httplogging /dontLog:true

第八步:Active Directory

了解 Active Directory Azure Active Directory 的差别,以及验证方式的不同。
Active Directory
  • NTLM
  • LDAP / LDAPS
  • KERBEROS
Azure Active Directory
  • SAML (安全性声明标记语言)
  • OAUTH 2.0
  • OpenID 连接

第九步:恶意脚本撰写

分析 APT 组织所撰写的恶意脚本内容,并学习该程式语言以及了解恶意脚本执行方式与内容。
  • PowerShell
  • VBScript
  • JavaScript
以上为透过分析 Techniques 初步制定红队演练的学习流程,可以再继续透过分析 Technique 了解更多攻击手法,将红队演练的知识树扩展。
参考网址
  • GitHub - redcanaryco/atomic-red-team: Small and highly portable detection tests based on MITRE's ATT&CK.

 

这篇关于[ATTCK] 分析攻击手法制定红队演练流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/418224

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

nodejs打包作为公共包使用的完整流程

《nodejs打包作为公共包使用的完整流程》在Node.js项目中,打包和部署是发布应用的关键步骤,:本文主要介绍nodejs打包作为公共包使用的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言一、前置准备二、创建与编码三、一键构建四、本地“白嫖”测试(可选)五、发布公共包六、常见踩坑提醒

Ubuntu向多台主机批量传输文件的流程步骤

《Ubuntu向多台主机批量传输文件的流程步骤》:本文主要介绍在Ubuntu中批量传输文件到多台主机的方法,需确保主机互通、用户名密码统一及端口开放,通过安装sshpass工具,准备包含目标主机信... 目录Ubuntu 向多台主机批量传输文件1.安装 sshpass2.准备主机列表文件3.创建一个批处理脚

一个Java的main方法在JVM中的执行流程示例详解

《一个Java的main方法在JVM中的执行流程示例详解》main方法是Java程序的入口点,程序从这里开始执行,:本文主要介绍一个Java的main方法在JVM中执行流程的相关资料,文中通过代码... 目录第一阶段:加载 (Loading)第二阶段:链接 (Linking)第三阶段:初始化 (Initia

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service