• 标 题:Winrar2.8到3.0升级手记 (7千字)
  • 作 者:hello!
  • 时 间:2002-6-1 17:37:59
  • 链 接:http://bbs.pediy.com

刚去网站溜达,好多网站都开始使用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!