首页
社区
课程
招聘
[原创]某USB狗验证+去功能限制的破解!(看雪首发)
发表于: 2010-6-24 09:15 14519

[原创]某USB狗验证+去功能限制的破解!(看雪首发)

2010-6-24 09:15
14519
【文章标题】: 某USB狗验证+去功能限制的破解!
【文章作者】: 阿杰
【作者邮箱】: 673943168@qq.com
【作者QQ号】: 673943168
【软件名称】: 某商业软件
【下载地址】: 由于是给客户破解的所以就不公布了
【保护方式】: USB狗加密
【使用工具】: OD
【作者声明】: 此文只用于技术探讨,没其他目的!

一款商业管理系统用了USB狗验证不插入USB功能受到限制!
破文开始:
查壳:无壳     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

--------------------------------------------------------------------------------------------------------
总结:
到此已经破解成功,保存运行已经是注册版,功能限制已经取消了,这套系统加密上明显存在缺陷,以至于USB验证形同虚设!在这里提醒一下新手朋友,不要碰到一些高级的加密验证方式就放弃了,要有种勇于探索的精神,crack是要不断的动手钻研,碰到困难要尽最大努力去克服这样才能进步!

呵呵!破文结束----------------------------------------------------------------------------------------------

--------------------------------------------------------------------------------
【版权声明】: 本文原创于阿杰, 转载请注明作者并保持文章的完整, 谢谢!

                                                       2010年06月24日 上午 09:22:35

[招生]科锐逆向工程师培训(2024年11月15日实地,远程教学同时开班, 第51期)

收藏
免费 0
支持
分享
最新回复 (23)
雪    币: 285
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
强悍,这种软件太伤脑筋了~~~~~~
2010-6-24 09:39
0
雪    币: 216
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
3
不错,又学习了
2010-6-24 09:49
0
雪    币: 18
活跃值: (12)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
学习一下,有空一定要学习暴破
2010-6-24 10:06
0
雪    币: 29
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
5
不错,原来usb加密狗也有很简单的啊。收益不少。谢谢了
2010-6-24 14:01
0
雪    币: 239
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
6
烂用USB狗,
2010-6-25 19:29
0
雪    币: 145
活跃值: (85)
能力值: ( LV5,RANK:60 )
在线值:
发帖
回帖
粉丝
7
强悍。这也奠定了 我的自信心,以前老以为有了加密狗就无法搞了的心里。
2010-6-25 21:18
0
雪    币: 226
活跃值: (72)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
8
以前公司用的商用软件就是带狗的,现在也都破解了。。。。。
2010-6-26 17:18
0
雪    币: 5286
活跃值: (3679)
能力值: ( LV13,RANK:283 )
在线值:
发帖
回帖
粉丝
9
这个软件厂商根本不懂狗的使用方法
2010-6-26 22:01
0
雪    币: 204
活跃值: (25)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
10
前几天就碰到了这种软件··都搞得我头疼了··来学习学习·
2010-6-27 22:21
0
雪    币: 3480
活跃值: (246)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
11
这篇文章该加精喽
2010-6-28 11:43
0
雪    币: 33
活跃值: (25)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
12
狗有时并不是多可怕的,前几天暴破个卡证制做软件,就是有加密狗的,试用版本打印出的卡证有水印。
暴破后,使用正常。
2010-6-28 22:55
0
雪    币: 166
活跃值: (12)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
13
这条狗也太弱了吧?
2010-6-29 13:16
0
雪    币: 9
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
14
思路挺好,就是,这种加密方法不算复杂!
2010-6-30 15:44
0
雪    币: 37
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
15
以后衣服干洗送你那去了?!
2010-6-30 22:20
0
雪    币: 431
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
16
学习了~~~
2010-6-30 22:24
0
雪    币: 45
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
17
每次在论坛发帖,都石沉大海,唉!不知道什么时候能加精啊!
2010-7-2 12:20
0
雪    币: 352
活跃值: (19)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
18
不错~!
2010-7-5 17:34
0
雪    币: 241
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
19
感觉的确如各位的大大所言,软件作者不会利用狗~ 这样的狗还不如一般的复杂算法加密来的好。。看来只能是纸老虎了
2010-7-15 11:00
0
雪    币: 207
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
20
这个应该是使用不当吧。感觉跟usb没什么关系一样。
2010-7-29 15:37
0
雪    币: 20
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
21
呵呵,这个商业软件也太弱智了。原来就是if(有狗){ 运行正版} else{学习版}
那只要修改一处强制跳转就可以了!呵呵,太弱了
2010-9-25 22:08
0
雪    币: 7
活跃值: (31)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
22
人家就是卖狗而已
2010-10-21 11:03
0
雪    币: 7
活跃值: (31)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
23
其实真的限制很多的话把所有调用狗的地方全部喀嚓估计也OK了
2010-10-21 11:04
0
雪    币: 202
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
24
很厉害啊。学习下啊
2010-10-30 12:36
0
游客
登录 | 注册 方可回帖
返回
//