刚去网站溜达,好多网站都开始使用RAR3.0标准压缩文件了,我还在用2.8,好象有点跟不上形式了,好吧,俺也去找个3.0,呵呵,还好不是我不喜欢的测试版,安装吧,看看说明,呵呵,注册用户可以从2.8免费升级,正合我意,恩,运行一下,怎么还是评估版呀,不是说可以升级的吗,我2.8也是注册版呀,55555,怎么就不行了呢?有点怀念2.8了.看来得想想办法了.
工具 W32DASM,TRW2000,HIEW
过程如下:
使用W32DASM反汇编后,首先找EVALUATION字样,呵呵,运气真好,一下就找到了
* Referenced by a CALL at Addresses:
|:0043F046 , :0044DBD6 , :00450157
|
:0043F984 81C400FCFFFF add esp, FFFFFC00
:0043F98A 50 push eax
* Possible StringData Ref from Data Obj ->"%s - WinRAR"
|
:0043F98B 6875664800 push 00486675
:0043F990 8D442408 lea eax, dword ptr [esp+08]
:0043F994 50 push eax
:0043F995 E8667A0300 call 00477400
:0043F99A 83C40C add esp, 0000000C
:0043F99D 803D1CDD480000 cmp byte ptr [0048DD1C], 00--->这里可以看出48DD1C是个全局变量,也就是注册标志
:0043F9A4 757A jne 0043FA20
:0043F9A6 A1B4DF4900 mov eax, dword ptr [0049DFB4]
:0043F9AB 83F814 cmp eax, 00000014--->小于20天时显示"evaluation copy"
:0043F9AE 7C05 jl 0043F9B5
:0043F9B0 83F828 cmp eax, 00000028--->小于40天大于20天时提醒购买
:0043F9B3 7C1D jl 0043F9D2
* Referenced by a (U)nconditional or (C)onditional Jump at Address:
|:0043F9AE(C)
|
* Possible Reference to String Resource ID=00873: "evaluation copy"
|
:0043F9B5 B869030000 mov eax, 00000369
:0043F9BA E8DDF1FCFF call 0040EB9C
:0043F9BF 50 push eax
:0043F9C0 8D942404020000 lea edx, dword ptr [esp+00000204]
:0043F9C7 52 push edx
:0043F9C8 E87B3C0300 call 00473648
:0043F9CD 83C408 add esp, 00000008
:0043F9D0 EB27 jmp 0043F9F9
* Referenced by a (U)nconditional or (C)onditional Jump at Address:
|:0043F9B3(C)
|
:0043F9D2 B928000000 mov ecx, 00000028
* Possible Reference to String Resource ID=00874: "only %d days left to buy a license"
|
:0043F9D7 B86A030000 mov eax, 0000036A
:0043F9DC 2B0DB4DF4900 sub ecx, dword ptr [0049DFB4]
:0043F9E2 51 push ecx
:0043F9E3 E8B4F1FCFF call 0040EB9C
既然找到了注册标志,那就看看是谁在对他进行设置吧
下断 BPM 48DD1C 呵呵,LOOK!
* Reference To: KERNEL32.GetLocalTime, Ord:0000h
|
:004367B3 E82AAB0400 Call 004812E2
:004367B8 33C0 xor eax, eax
:004367BA E88D52FDFF call 0040BA4C--->呼叫验证核心
:004367BF A21CDD4800 mov byte ptr [0048DD1C], al--->这里写入标志,看来上面这个CALL是检测核心
:004367C4 33C0 xor eax, eax
:004367C6 E9270E0000 jmp 004375F2
哦,好的,我们到核心再去看看吧: )
* Referenced by a CALL at Addresses:
|:0043658A , :004367BA , :0043E6F4 , :0043F030 , :00450363
|
:0040BA4C 55 push ebp
:0040BA4D 8BEC mov ebp, esp
:0040BA4F 81C404F0FFFF add esp, FFFFF004
:0040BA55 50 push eax
:0040BA56 81C448FDFFFF add esp, FFFFFD48
:0040BA5C 53 push ebx
:0040BA5D 56 push esi
:0040BA5E 57 push edi
:0040BA5F 8885E3FEFFFF mov byte ptr [ebp+FFFFFEE3], al
:0040BA65 BE18D74800 mov esi, 0048D718
:0040BA6A B838324800 mov eax, 00483238
:0040BA6F E874800600 call 00473AE8
:0040BA74 8D95C8FAFFFF lea edx, dword ptr [ebp+FFFFFAC8]
* Possible StringData Ref from Data Obj ->"rarreg.*"
|
:0040BA7A B85F2E4800 mov eax, 00482E5F
:0040BA7F E815F5FFFF call 0040AF99--->程序检查是否有一个名字是RARREG的文件
:0040BA84 84C0 test al, al
:0040BA86 7514 jne 0040BA9C
:0040BA88 33C0 xor eax, eax
:0040BA8A 8B95E4FEFFFF mov edx, dword ptr [ebp+FFFFFEE4]
:0040BA90 64891500000000 mov dword ptr fs:[00000000], edx
:0040BA97 E9CF050000 jmp 0040C06B--->玩完
恩,我好象有一个文件名字是RARREG.KEY的文件,把它改这个名字好了,然后,一路走,走,走,来到了这里
* Referenced by a (U)nconditional or (C)onditional Jump at Address:
|:0040BC86(C)
|
:0040BC34 8B3C9D302E4800 mov edi, dword ptr [4*ebx+00482E30]
:0040BC3B 57 push edi
:0040BC3C E8377A0600 call 00473678
:0040BC41 59 pop ecx
:0040BC42 8BC8 mov ecx, eax
:0040BC44 8BD7 mov edx, edi--->EDX的东西好眼熟,好象在哪里看到过呀,对了,在我的RARREG文件里好象也有这么一堆字符
:0040BC46 8D8548F6FFFF lea eax, dword ptr [ebp+FFFFF648]
:0040BC4C E85B060000 call 0040C2AC--->黑名单比较
:0040BC51 85C0 test eax, eax--->上了黑名单吗?好惨: (
:0040BC53 752D jne 0040BC82--->没有上黑名单?恭喜,下面就一路顺风了: )
:0040BC55 33C0 xor eax, eax
:0040BC57 BA02000000 mov edx, 00000002
:0040BC5C 50 push eax
:0040BC5D 8D8508FFFFFF lea eax, dword ptr [ebp+FFFFFF08]
:0040BC63 83AD00FFFFFF04 sub dword ptr [ebp+FFFFFF00], 00000004
:0040BC6A E8BD070000 call 0040C42C
:0040BC6F 58 pop eax
:0040BC70 8B95E4FEFFFF mov edx, dword ptr [ebp+FFFFFEE4]
:0040BC76 64891500000000 mov dword ptr fs:[00000000], edx
:0040BC7D E9E9030000 jmp 0040C06B--->又玩完
跟到这里终于发现,原来我的RARREG里的东西上了黑名单了: (,怎么办?: ((((,既然别的都认可了,那说明作者说的话是真的,可以直接从2.8升级到3.0,恩,有了,我把黑名单换一下好了,在名单上的滋味可不好,人怕出名猪怕壮呀: )
呵呵,看看程序的空间,觉得这里好象是最理想的地方,用HIEW改吧 : )
//******************** Program Entry Point ********
:00401000 EB10 jmp 00401012 --->这里改EB09
:00401002 66623A bound di, word ptr [edx]
:00401005 43 inc ebx
:00401006 2B2B sub ebp, dword ptr [ebx]
:00401008 48 dec eax
:00401009 4F dec edi
:0040100A 4F dec edi
:0040100B 4B dec ebx --->这里开始改成C605402F080033(注意,这是把和我自己的注册文件里的相同的一组数据中一个字符给改了,可能和大家的情况有点不同,请自己修改)
:0040100C 90 nop
:0040100D E9C4214800 jmp 008831D6
* Referenced by a (U)nconditional or (C)onditional Jump at Address:
|:00401000(U)
|
:00401012 A1B7214800 mov eax, dword ptr [004821B7]--->程序入口
好,运行一下,呵呵,怎么样,想必大家都知道了 : ) ,我天生比较懒,所以想了这么个懒办法 : )
在这里有了点问题,请高手指教,我用TRW载入的时候,发现黑名单随着程序载入,已经存在,不能判断数据源在哪里,用资源工具也没找到这些数据的踪影,若我想拦截这些数据装入时该怎么办?
hello!