data:image/s3,"s3://crabby-images/eca9f/eca9f2f56c05c552c853355d850e1be1b77847b1" alt="Rank: 15" data:image/s3,"s3://crabby-images/eca9f/eca9f2f56c05c552c853355d850e1be1b77847b1" alt="Rank: 15" data:image/s3,"s3://crabby-images/eca9f/eca9f2f56c05c552c853355d850e1be1b77847b1" alt="Rank: 15" data:image/s3,"s3://crabby-images/d1faa/d1faa948cbc21e6e1634b0d994d9daf499ed9fa0" alt="Rank: 15" data:image/s3,"s3://crabby-images/55d42/55d42d19a311950367b6865f5dcfa0ed433eaef9" alt="Rank: 15"
- 帖子
- 3852
- 积分
- 13044
- 威望
- 16780
- 金钱
- 36761
- 在线时间
- 1139 小时
data:image/s3,"s3://crabby-images/4732a/4732a86c86fd37ff85e553f122d614c7ccbe00a5" alt="管理组 管理组" data:image/s3,"s3://crabby-images/9ae68/9ae686c72fd588bd7968d64fc16b8b60a73761c2" alt="高手勋章 高手勋章" data:image/s3,"s3://crabby-images/098ce/098ced5e61263a3e4d5f4108f37d875e10fcdbb2" alt="核心成员 核心成员" data:image/s3,"s3://crabby-images/e6314/e631450ec076e04beca50708b36d5c815d6e95e6" alt="原创奖章 原创奖章" data:image/s3,"s3://crabby-images/ccea7/ccea754c16c006eaac7a96f5b73f0d004d0ccb45" alt="帅哥勋章 帅哥勋章" data:image/s3,"s3://crabby-images/55154/551549a43b8b41730409c4a970b2358b5153ff45" alt="突出贡献奖 突出贡献奖" data:image/s3,"s3://crabby-images/63d52/63d5297982a03d194afcb13981f3232a383b8e34" alt="优质人品奖章 优质人品奖章" data:image/s3,"s3://crabby-images/b23b3/b23b3fed8495e8121d3d2728c95aaa8a3246c2e7" alt="论坛元老 论坛元老" data:image/s3,"s3://crabby-images/ad595/ad5951204df425fe3a00c0711513481a8b68a2ce" alt="管理组成员 管理组成员" data:image/s3,"s3://crabby-images/0b534/0b5349fc17d5e03b07feb7e4030f01eec8845c2a" alt="技术组成员 技术组成员"
|
发现手改花指令太无聊,于是简单学了下IDC,觉得不爽,但是为了稍微节省些体力,还是硬着头皮写了一个,可能有bug,能改的花指令也很有限,我只为了应付我碰到的情况,有和我同样情况的可以直接用,效果应该还行,但是做的不完全,只是把一些无用的花指令替换成0x90,没有重新分析,如果碰到IDA提示红字的地方,按D再按C,呵呵.
代码:
#include <idc.idc>
static matchBytes(StartAddr, Match)
{
auto Len, i, PatSub, SrcSub;
Len = strlen(Match);
while (i < Len)
{
PatSub = substr(Match, i, i+1);
SrcSub = form("%02X", Byte(StartAddr));
SrcSub = substr(SrcSub, i % 2, (i % 2) + 1);
if (PatSub != "?" && PatSub != SrcSub)
{
return 0;
}
if (i % 2 == 1)
{
StartAddr++;
}
i++;
}
return 1;
}
static main()
{
auto StartVa, SavedStartVa, StopVa, Size, i, j;
StartVa = 0x000102A0;
StopVa = 0x000120A0;
Size = StopVa - StartVa;
SavedStartVa = StartVa;
for (i = 0; i < Size; i++)
{
// 0F 82 07 00 00 00 0F 83 01 00 00 00
// jz xxxx + jnz xxxx + 0xE8
// 0F 84 07 00 00 00 0F 85 01 00 00 00 E8
// jo xxxx + jno xxxx + 0xE8
// 0F 80 07 00 00 00 0F 81 01 00 00 00 E8
// js xxxx + jns xxxx + 0xE8
// 0F 88 07 00 00 00 0F 89 01 00 00 00 E8
if (matchBytes(StartVa, "0F8?070000000F8?01000000E8"))
{
for (j = 0; j < 13; j++)
{
PatchByte(StartVa, 0x90);
MakeCode(StartVa);
StartVa++;
}
}
// jb short near xxxx + jnb short near xxxx + 0xE8
// 72 03 73 01 E8
// jo short near xxxx + jno short near xxxx + 0xE8
// 70 03 71 01 E8
// jz short near xxxx + jnz short near xxxx + 0xE8
// 74 03 75 01 E8
if (matchBytes(StartVa, "7?037?01E8"))
{
for (j = 0; j < 5; j++)
{
PatchByte(StartVa, 0x90);
MakeCode(StartVa);
StartVa++;
}
}
StartVa++;
}
AnalyzeArea(SavedStartVa, StopVa);
Message("Clear Fake-Jmp Opcode Ok\n");
} |
|