UXP的入门特征码审查

本文介绍了UXP特征码审查的基本方法,重点关注了一段特定的特征码序列,并提供了一个简单的审查程序逻辑。该程序通过创建文件映射,利用PE文件结构找到OEP,然后对比前16个字节码来完成初步审查。
摘要由CSDN通过智能技术生成

关于UXP特征码的审查

 

只有画红线的部分会因为不同的程序字节码不同,其他的从EP开始基本不变对于基本的UXP可以很好的找到特征码 "\x60\xbe????\x8d\xbe????\x57\x83\xcd\xff",(问号表示不确定,其实如果能熟读PE文件结构的话可以把问号的内容还原出来,但是作为一个审查程序,没必要,这些特征码已经足够进行一些简单的审查了)

贴出源代码

#include<stdio.h>
#include<windows.h>
#define NAMELEN 20
#define SIGNLEN 32
typedef struct _SIGN
{
	char szName[NAMELEN];
	BYTE bSign[SIGNLEN+1];
}SIGN,*PSIGN;
SIGN Sign=
{
	"UPX","\x60\xbe????\x8d\xbe????\x57\x83\xcd\xff"
};
BOOL SignJuge(HANDLE hMap)
{
	LPVOID m_Base=NULL;
	m_Base=MapViewOfFile(hMap,FILE_MAP_READ|FILE_SHARE_READ,0,0,0);
	PIMAGE_DOS_HEADER m_DosHeader=(PIMAGE_DOS_HEADER)m_Base;
	//printf("Dos_Header: %x\n",m_DosHeader->e_lfanew);
	PIMAGE_NT_HEADERS m_NtHeader=(PIMAGE_NT_HEADERS)((DWORD)m_Base+(DWORD)m_DosHead
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值