如何优雅的放置你的shellcode(二)
2023-6-4 13:30:54 Author: 应龙信安攻防实验室(查看原文) 阅读量:22 收藏

0X00 前言

在昨天的文章:如何优雅的放置你的shellcode(一)中我们探讨了shellcode放置的几种方式,今天将接着昨天的文章,完成我们对.rsrc 区段的探讨。在我们实际的shelcode放置中,这也是一种比较好的方法,因为这个区段的优点有很多,比如可以存放更多的shellcode。

0X01 rsrc实现

我们先添加一个.rc 资源文件

然后导入一个ico

在到这一步的时候,我们输入RCDATA

导入之后,我们的shellcode便会以二进制形式展示出来

同时会出现一个resource.h 的头文件,这个文件包含一个定义语句,这个语句能够引用资源部分中的shellcode ID

当我们编译后,shelcode将存储在该.rdata 区段,但无法直接访问。这个时候我们必须使用多个 Win32API 来访问。

FindResourceW获取传入ID的资源段中指定数据的存储位置(这个在头文件中定义)
LoadResource检索可用于获取指向内存中指定资源的第一个字节的指针的句柄
LockResource检索指向内存中指定资源的指针
SizeofResource返回指定资源的字节数大小
#include <stdio.h>
#include <Windows.h>
#include "resource.h"

int main() {

 HRSRC  hRsrc = NULL;
 HGLOBAL  hGlobal = NULL;
 PVOID  pPayloadAddress = NULL;
 SIZE_T  sPayloadSize = NULL;

 // 获取存储在.rsrc中的数据的位置
 hRsrc = FindResourceW(NULL, MAKEINTRESOURCEW(IDR_RCDATA1), RT_RCDATA);
 if (hRsrc == NULL) {
  printf("FindResourceW Failed With Error : %d \n", GetLastError());
  return -1;
 }

 // 获取句柄
 hGlobal = LoadResource(NULL, hRsrc);
 if (hGlobal == NULL) {
  printf("LoadResource Failed With Error : %d \n", GetLastError());
  return -1;
 }

 // 在.rsrc区段获取shellcode的地址
 pPayloadAddress = LockResource(hGlobal);
 if (pPayloadAddress == NULL) {
  printf("LockResource Failed With Error : %d \n", GetLastError());
  return -1;
 }

 // 在.rsrc区段获取shellcode的大小
 sPayloadSize = SizeofResource(NULL, hRsrc);
 if (sPayloadSize == NULL) {
  printf("SizeofResource Failed With Error : %d \n", GetLastError());
  return -1;
 }

 printf("Address is : 0x%p \n", pPayloadAddress);
 printf("Size is : %ld \n", sPayloadSize);

 return 0;
}

编译并运行上述代码后,会把shellcode地址及其大小打印出来。但是这个地址位于 .rsrc 区段,这个区段是只读的,我们任何更改或编辑其中数据的操作都会导致访问错误。想要编辑shellcode,我们只能分配一个与shellcode大小相同的临时缓冲区并把shellcode复制过来,然后我们对这个缓冲区进行操作即可。

// 分配内存
PVOID pTmpBuffer = HeapAlloc(GetProcessHeap(), 0, sPayloadSize);
if (pTmpBuffer != NULL) {
 memcpy(pTmpBuffer, pPayloadAddress, sPayloadSize);
}

printf("new Address is : 0x%p \n", pTmpBuffer);

资源中的内存情况

临时缓冲区中的内存情况

0x02 小结

本文接着昨天的文章:如何优雅的放置你的shellcode(一) 继续探讨了.rsrc 区段放置shellcode的方法,区别于昨天的方法,.rsrc 区段的实现方法较为繁琐,需要多个Win32API来辅助我们实现对shellcode的访问。但是效果比较好,在很多时候也是一种行之有效的办法。注:本文仅用于安全研究和学习之用

TIPS

应龙安全-红蓝对抗 知识星球
有兴趣就加,没什么多说的

文章来源: http://mp.weixin.qq.com/s?__biz=Mzk0NjMyNDcxMg==&mid=2247500327&idx=1&sn=8d4827896a640f30b49e85264a36a6e6&chksm=c30557a0f472deb653f1135ff2d8d34cc20829413a1ab4904448877ca225848fe640415c333f#rd
如有侵权请联系:admin#unsafe.sh