某delphi程序加密狗破解过程

查壳:无壳     Borland Delphi 6.0 – 7.0
OD载入 F9运行弹出:未检测到软件狗,试用版软件部分功能将受到限制!
F12暂停
————————————————————————————-
7C92E514 >    C3            retn                                     ;  (初始 cpu 选择)
7C92E515   .  8DA424 000000>lea esp,dword ptr ss:[esp]
7C92E51C   .  8D6424 00     lea esp,dword ptr ss:[esp]
7C92E520 >/$  8D5424 08     lea edx,dword ptr ss:[esp+8]
7C92E524  |.  CD 2E         int 2E
7C92E526  \.  C3            retn
7C92E527      90            nop
7C92E528 >/$  55            push ebp
7C92E529  |.  8BEC          mov ebp,esp
————————————————————————————–
ALT+K调用堆栈
调用堆栈 

0012FD34   77D50877   ? user32.MessageBoxTimeoutA           user32.77D50872               0012FD30
0012FD54   77D5082F   ? user32.MessageBoxExA                user32.77D5082A               0012FD50
0012FD58   00000000     hOwner = NULL
0012FD5C   0063B9E0     Text = “未检测到软件狗,试用版软件
0012FD60   004E0040     Title = “提示”
0012FD64   00002040     Style = MB_OK|MB_ICONASTERISK|MB_T
0012FD68   00000000     LanguageID = 0 (LANG_NEUTRAL)
0012FD70   004E000A   ? <jmp.&user32.MessageBoxA>           Washgl.004E0005               0012FD6C
0012FD74   00000000     hOwner = NULL
0012FD78   0063B9E0     Text = “未检测到软件狗,试用版软件
0012FD7C   004E0040     Title = “提示”
0012FD80   00002040     Style = MB_OK|MB_ICONASTERISK|MB_T
0012FD8C   0063B7DC   ? Washgl.004DFFE4                     Washgl.0063B7D7  在这句双击进去

———————————————————————————————-
0063B79D   .  55            push ebp
0063B79E   .  68 FFB86300   push Washgl.0063B8FF
0063B7A3   .  64:FF32       push dword ptr fs:[edx]
0063B7A6   .  64:8922       mov dword ptr fs:[edx],esp
0063B7A9   .  E8 0235EBFF   call Washgl.004EECB0
0063B7AE   .  A2 00416400   mov byte ptr ds:[644100],al
0063B7B3   .  A1 EC496400   mov eax,dword ptr ds:[6449EC]
0063B7B8   .  8A15 00416400 mov dl,byte ptr ds:[644100]
0063B7BE   .  8810          mov byte ptr ds:[eax],dl
0063B7C0   .  A0 00416400   mov al,byte ptr ds:[644100]
0063B7C5   .  34 01         xor al,1
0063B7C7   .  84C0          test al,al
0063B7C9   .  84C0          test al,al
0063B7CB      74 5F         je short Washgl.0063B82C      整个调用只有这一个能跳过所以改成jmp顺利跳过去了   
0063B7CD   .  B8 E0B96300   mov eax,Washgl.0063B9E0
0063B7D2   .  BA 01000000   mov edx,1
0063B7D7   .  E8 0848EAFF   call Washgl.004DFFE4          双击进去在这,这就是关键CLL了
0063B7DC   .  8D55 F4       lea edx,dword ptr ss:[ebp-C]
0063B7DF   .  A1 2C656400   mov eax,dword ptr ds:[64652C]
0063B7E4   .  E8 5F89E1FF   call Washgl.00454148
0063B7E9   .  8D45 F4       lea eax,dword ptr ss:[ebp-C]
0063B7EC   .  BA 18BA6300   mov edx,Washgl.0063BA18
0063B7F1   .  E8 FE93DCFF   call Washgl.00404BF4
0063B7F6   .  8B55 F4       mov edx,dword ptr ss:[ebp-C]
0063B7F9   .  A1 2C656400   mov eax,dword ptr ds:[64652C]
0063B7FE   .  E8 7589E1FF   call Washgl.00454178
0063B803   .  A1 08476400   mov eax,dword ptr ds:[644708]
0063B808   .  E8 2791DCFF   call Washgl.00404934
0063B80D   .  A1 04476400   mov eax,dword ptr ds:[644704]
0063B812   .  E8 1D91DCFF   call Washgl.00404934
0063B817   .  8B45 FC       mov eax,dword ptr ss:[ebp-4]
0063B81A   .  8B80 FC020000 mov eax,dword ptr ds:[eax+2FC]
0063B820   .  33D2          xor edx,edx
0063B822   .  E8 19A9E2FF   call Washgl.00466140
0063B827   .  E9 C5000000   jmp Washgl.0063B8F1
—————————————————————————————————
再次尝试进入软件此时无提示进入软件而且,窗体上的(试用版已经没了)点关于:还是试用版功能依然限制!
此时重新载入OD,查找字符串!(对于Borland Delphi这招很好用)
超级字串参考+        
地址       反汇编                                    文本字串
0051FE24   mov edx,Washgl.0051FEA0                   退出
0051FE30   mov eax,Washgl.0051FEA8                   非法用户,系统将关闭!
0051FE41   mov eax,Washgl.0051FEC0                   非法用户,重新登录失败!
0051FE61   mov eax,Washgl.0051FEDC                   口令无效,请重新输入!
005206EB   mov edx,Washgl.00520774                   试用版
005206FA   mov edx,Washgl.00520784                   注册版     
00520712   push Washgl.00520794                      v
0052071E   push Washgl.005207A0                      \n
———————————————————————————————–
在试用版那双击进入!
005206CC  |.  55            push ebp
005206CD  |.  68 5E075200   push Washgl.0052075E
005206D2  |.  64:FF30       push dword ptr fs:[eax]
005206D5  |.  64:8920       mov dword ptr fs:[eax],esp
005206D8  |.  8BC3          mov eax,ebx
005206DA  |.  E8 E5000000   call Washgl.005207C4
005206DF  |.  E8 CCE5FCFF   call Washgl.004EECB0
005206E4  |.  84C0          test al,al                                比较
005206E6  |.  75 0F         jnz short Washgl.005206F7                 关键跳!jnz改jmp  直接跳到注册版  
005206E8  |.  8D45 FC       lea eax,[local.1]
005206EB  |.  BA 74075200   mov edx,Washgl.00520774                  ;  试用版
005206F0  |.  E8 D742EEFF   call Washgl.004049CC
005206F5  |.  EB 0D         jmp short Washgl.00520704
005206F7  |>  8D45 FC       lea eax,[local.1]
005206FA  |.  BA 84075200   mov edx,Washgl.00520784                  ;  注册版
005206FF  |.  E8 C842EEFF   call Washgl.004049CC
00520704  |>  8B55 FC       mov edx,[local.1]
00520707  |.  8B83 00030000 mov eax,dword ptr ds:[ebx+300]
0052070D  |.  E8 663AF3FF   call Washgl.00454178
00520712  |.  68 94075200   push Washgl.00520794                     ;  v
00520717  |.  A1 B8416400   mov eax,dword ptr ds:[6441B8]
0052071C  |.  FF30          push dword ptr ds:[eax]
0052071E  |.  68 A0075200   push Washgl.005207A0                     ;  \n
00520723  |.  68 AC075200   push Washgl.005207AC                     ;  版权所有(c) 2007-2017

相关推荐

发表评论

您的电子邮箱地址不会被公开。

QQ点我咨询