飘云阁

 找回密码
 加入我们

QQ登录

只需一步,快速开始

查看: 12974|回复: 15

[原创] KeyGenMe2007_C简单算法分析+VB注册机源码

[复制链接]
  • TA的每日心情
    奋斗
    2016-10-21 20:30
  • 签到天数: 1 天

    [LV.1]初来乍到

    发表于 2007-6-13 13:36:33 | 显示全部楼层 |阅读模式
    【破文标题】KeyGenMe2007_C简单算法分析+VB注册机源码
    破解作者】hrbx
    【作者主页】hrbx.ys168.com
    【作者邮箱】[email protected]
    【破解平台】WinXP
    【使用工具】flyOD1.10、Peid
    【破解日期】2007-06-13
    【软件名称】KeyGenMe2007_C
    【软件大小】67KB
    【下载地址】https://www.chinapyg.com/viewthread.php?tid=16561
    【加壳方式】UPX 0.89.6 - 1.02 / 1.05 - 1.24 -> Markus & Laszlo
    【软件简介】KeyGenMe2007_C[WWW.CHINAPYG.COM]
    -----------------------------------------------------------------------------------------------
    【破解声明】我是一只小菜鸟,偶得一点心得,愿与大家分享:)
    -----------------------------------------------------------------------------------------------
    【破解过程】

    1. 1.脱壳。用Peid扫描程序,显示为:UPX 0.89.6 - 1.02 / 1.05 - 1.24 -> Markus & Laszlo。ESP定律脱之,再次用Peid核心扫描,显示为:Microsoft Visual C++ 6.0。
    2. 2.试运行。运行程序,输入注册信息后,点"OK"按钮没有任何提示。
    3. 3.追出算法。OD载入脱壳后的程序,F9运行,输入注册信息:

    4. ====================================================
    5. RegName:hrbx
    6. RegCode:9876543210
    7. ====================================================

    8. 转到OD,ALT+M,右键--搜索,输入注册名:hrbx,找到后右键--断点--内存访问,回到程序,点"OK"按钮,立即中断:

    9. 77D32169     881F               mov byte ptr ds:[edi],bl                   ; 内存访问后中断在这里
    10. 77D3216B     8B4D 08            mov ecx,dword ptr ss:[ebp+8]
    11. 77D3216E     E8 6D63FEFF        call USER32.77D184E0
    12. 77D32173     8BF0               mov esi,eax

    13. F8往下, 走回程序领空,来到:

    14. 00402490     56                 push esi
    15. 00402491     8BF1               mov esi,ecx
    16. 00402493     6A 01              push 1
    17. 00402495     E8 585D0000        call <jmp.&MFC42.#6334_CWnd::UpdateData>
    18. 0040249A     74 03              je short Unpacked.0040249F                 ; F8返回这里
    19. 0040249C     75 01              jnz short Unpacked.0040249F
    20. 0040249E     68 8B862C01        push 12C868B
    21. 004024A3     0000               add byte ptr ds:[eax],al
    22. 004024A5     8378 F8 2D         cmp dword ptr ds:[eax-8],2D                ; 比较注册码长度是否为0x2D(45)
    23. 004024A9     0F85 FF000000      jnz Unpacked.004025AE                      ; 不等则Over,暴破点1,改为Nop
    24. 004024AF     74 03              je short Unpacked.004024B4
    25. 004024B1     75 01              jnz short Unpacked.004024B4
    26. 004024B3     68 EB01858B        push 8B8501EB
    27. 004024B8     8E2C01             mov gs,word ptr ds:[ecx+eax]
    28. 004024BB     0000               add byte ptr ds:[eax],al                   ; 依次取注册码特定位置的字符运算
    29. 004024BD     8A41 06            mov al,byte ptr ds:[ecx+6]                 ; 第7位
    30. 004024C0     8A51 05            mov dl,byte ptr ds:[ecx+5]                 ; 第6位
    31. 004024C3     33C2               xor eax,edx                                ; 第7位 xor 第6位
    32. 004024C5     0FBE51 07          movsx edx,byte ptr ds:[ecx+7]              ; 第8位
    33. 004024C9     83E0 7F            and eax,7F                                 ; (第7位 xor 第6位)and 0x7F
    34. 004024CC     0FBE49 04          movsx ecx,byte ptr ds:[ecx+4]              ; 第5位
    35. 004024D0     0FAFC2             imul eax,edx                               ; ((第7位 xor 第6位)and 0x7F)*第8位
    36. 004024D3     03C1               add eax,ecx                                ; ((第7位 xor 第6位)and 0x7F)*第8位+第5位
    37. 004024D5     B9 6B000000        mov ecx,6B                                 ; ECX=0x6B,常数1
    38. 004024DA     99                 cdq
    39. 004024DB     F7F9               idiv ecx                                   ; EAX/ECX
    40. 004024DD     85D2               test edx,edx                               ; EDX=余数
    41. 004024DF     0F85 C9000000      jnz Unpacked.004025AE                      ; 不能整除则Over,暴破点2,改为Nop
    42. 004024E5     74 03              je short Unpacked.004024EA
    43. 004024E7     75 01              jnz short Unpacked.004024EA
    44. 004024E9     68 74037501        push 1750374
    45. 004024EE     68 EB0185EB        push EB8501EB
    46. 004024F3     0185 8B8E2C01      add dword ptr ss:[ebp+12C8E8B],eax
    47. 004024F9     0000               add byte ptr ds:[eax],al
    48. 004024FB     0FBE41 0A          movsx eax,byte ptr ds:[ecx+A]              ; 第11位
    49. 004024FF     0FBE51 09          movsx edx,byte ptr ds:[ecx+9]              ; 第10位
    50. 00402503     23C2               and eax,edx                                ; 第11位 and 第10位
    51. 00402505     0FBE51 0B          movsx edx,byte ptr ds:[ecx+B]              ; 第12位
    52. 00402509     0FBE49 08          movsx ecx,byte ptr ds:[ecx+8]              ; 第9位
    53. 0040250D     0FAFC2             imul eax,edx                               ; (第11位 and 第10位)*第12位
    54. 00402510     03C1               add eax,ecx                                ; (第11位 and 第10位)*第12位+第9位
    55. 00402512     B9 65000000        mov ecx,65                                 ; ECX=0x65,常数2
    56. 00402517     99                 cdq
    57. 00402518     F7F9               idiv ecx                                   ; EAX/ECX
    58. 0040251A     83FA 08            cmp edx,8                                  ; EDX=余数,余数与8比较
    59. 0040251D     0F85 8B000000      jnz Unpacked.004025AE                      ; 不等则Over,暴破点3,改为Nop
    60. 00402523     EB 01              jmp short Unpacked.00402526
    61. 00402525     85EB               test ebx,ebp
    62. 00402527     0185 8B8E2C01      add dword ptr ss:[ebp+12C8E8B],eax
    63. 0040252D     0000               add byte ptr ds:[eax],al
    64. 0040252F     0FBE41 0E          movsx eax,byte ptr ds:[ecx+E]              ; 第15位
    65. 00402533     0FBE51 0D          movsx edx,byte ptr ds:[ecx+D]              ; 第14位
    66. 00402537     0FAFC2             imul eax,edx                               ; 第15位 * 第14位
    67. 0040253A     0FBE51 0F          movsx edx,byte ptr ds:[ecx+F]              ; 第16位
    68. 0040253E     0FBE49 0C          movsx ecx,byte ptr ds:[ecx+C]              ; 第13位
    69. 00402542     03C2               add eax,edx                                ; (第15位 * 第14位)+第16位
    70. 00402544     03C1               add eax,ecx                                ; (第15位 * 第14位)+第16位+第13位
    71. 00402546     B9 69000000        mov ecx,69                                 ; ECX=0x69,常数3
    72. 0040254B     99                 cdq
    73. 0040254C     F7F9               idiv ecx                                   ; EAX/ECX
    74. 0040254E     85D2               test edx,edx                               ; EDX=余数
    75. 00402550     75 5C              jnz short Unpacked.004025AE                ; 不能整除则Over,暴破点4,改为Nop
    76. 00402552     74 03              je short Unpacked.00402557
    77. 00402554     75 01              jnz short Unpacked.00402557
    78. 00402556     68 EB01858B        push 8B8501EB
    79. 0040255B     8E2C01             mov gs,word ptr ds:[ecx+eax]
    80. 0040255E     0000               add byte ptr ds:[eax],al
    81. 00402560     0FBE41 12          movsx eax,byte ptr ds:[ecx+12]             ; 第19位
    82. 00402564     0FBE51 11          movsx edx,byte ptr ds:[ecx+11]             ; 第18位
    83. 00402568     0BC2               or eax,edx                                 ; 第19位 or 第18位
    84. 0040256A     0FBE51 13          movsx edx,byte ptr ds:[ecx+13]             ; 第20位
    85. 0040256E     0FBE49 10          movsx ecx,byte ptr ds:[ecx+10]             ; 第17位
    86. 00402572     0FAFC2             imul eax,edx                               ; (第19位 or 第18位)*第20位
    87. 00402575     03C1               add eax,ecx                                ; (第19位 or 第18位)*第20位+第17位
    88. 00402577     B9 69000000        mov ecx,69                                 ; ECX=0x69,常数3
    89. 0040257C     99                 cdq
    90. 0040257D     F7F9               idiv ecx                                   ; EAX/ECX
    91. 0040257F     85D2               test edx,edx                               ; EDX=余数
    92. 00402581     75 2B              jnz short Unpacked.004025AE                ; 不能整除则Over,暴破点5,改为Nop
    93. 00402583     EB 01              jmp short Unpacked.00402586                ; 在此处按Enter
    94. 00402585     8581 7E60CB4B      test dword ptr ds:[ecx+4BCB607E],eax
    95. 0040258B     A4                 movs byte ptr es:[edi],byte ptr ds:[esi]
    96. 0040258C     0D 74187403        or eax,3741874
    97. 00402591     75 01              jnz short Unpacked.00402594
    98. 00402593     68 8BCEE855        push 55E8CE8B
    99. 00402598     0300               add eax,dword ptr ds:[eax]
    100. 0040259A     00EB               add bl,ch
    101. 0040259C     0185 8BCEE80B      add dword ptr ss:[ebp+BE8CE8B],eax
    102. 004025A2     04 00              add al,0
    103. 004025A4     00EB               add bl,ch
    104. 004025A6     07                 pop es
    105. 004025A7     8BCE               mov ecx,esi
    106. 004025A9     E8 42020000        call Unpacked.004027F0
    107. 004025AE     8B56 20            mov edx,dword ptr ds:[esi+20]
    108. 004025B1     6A 01              push 1
    109. 004025B3     52                 push edx
    110. 004025B4     FF15 2C934000      call dword ptr ds:[<&USER32.KillTimer>]    ; USER32.KillTimer
    111. 004025BA     6A 00              push 0
    112. 004025BC     8BCE               mov ecx,esi
    113. 004025BE     E8 2F5C0000        call <jmp.&MFC42.#6334_CWnd::UpdateData>
    114. 004025C3     5E                 pop esi
    115. 004025C4     C3                 retn

    116. 由于程序有花指令干扰,调试时应注意。
    117. 调试到00402583处,直接按Enter,来到00402586处:

    118. 00402586     817E 60 CB4BA40D   cmp dword ptr ds:[esi+60],0DA44BCB         ; 比较ds:[esi+60]处的值与0DA44BCB是否相等
    119. 0040258D     74 18              je short Unpacked.004025A7                 ; 不等则Over,暴破点6,改为jmp
    120. 0040258F     74 03              je short Unpacked.00402594
    121. 00402591     75 01              jnz short Unpacked.00402594
    122. 00402593     68 8BCEE855        push 55E8CE8B

    123. 看一下程序是在什么地方给ds:[esi+60]处赋值的。
    124. 修改上面几处暴破点的跳转,来到00402586处,观察窗口提示:

    125. ==================================
    126. 堆栈 ds:[0012FE20]=0001E240
    127. ==================================

    128. 命令栏输入:d 0012fe20,对0012fe20处下断:右键--断点--设置硬件访问断点-Byte(不能下"内存访问"断点,否则会异常)
    129. F9运行程序,弹出2个伪注册成功提示窗体,确定后随便更改一下用户名,立即中断:

    130. 004027B0     56                 push esi
    131. 004027B1     8BF1               mov esi,ecx
    132. 004027B3     6A 01              push 1
    133. 004027B5     E8 385A0000        call <jmp.&MFC42.#6334_CWnd::UpdateData>
    134. 004027BA     8B86 30010000      mov eax,dword ptr ds:[esi+130]             ; 用户名
    135. 004027C0     8378 F8 05         cmp dword ptr ds:[eax-8],5                 ; 用户名长度与5比较
    136. 004027C4     7C 1E              jl short Unpacked.004027E4                 ; 小于则跳至004027E4
    137. 004027C6     8B8E 2C010000      mov ecx,dword ptr ds:[esi+12C]             ; 注册码
    138. 004027CC     8379 F8 2D         cmp dword ptr ds:[ecx-8],2D                ; 注册码长度与0x2D(45)比较
    139. 004027D0     75 12              jnz short Unpacked.004027E4                ; 不相等则跳至004027E4
    140. 004027D2     8B56 20            mov edx,dword ptr ds:[esi+20]
    141. 004027D5     6A 00              push 0
    142. 004027D7     6A 0A              push 0A
    143. 004027D9     6A 01              push 1
    144. 004027DB     52                 push edx
    145. 004027DC     FF15 30934000      call dword ptr ds:[<&USER32.SetTimer>]     ; USER32.SetTimer
    146. 004027E2     5E                 pop esi
    147. 004027E3     C3                 retn
    148. 004027E4     C746 60 40E20100   mov dword ptr ds:[esi+60],1E240            ; 对ds:[esi+60]处赋值0x1E240
    149. 004027EB     5E                 pop esi                                    ; 下硬件访问断点后在此中断
    150. 004027EC     C3                 retn

    151. 由以上代码可知,用户名必须不小于5位,注册码必须为0x2D(45)位,否则对对ds:[esi+60]处赋值0x1E240。

    152. 确定0012fe20处的"硬件访问断点"没有删除,继续F9运行程序,来到:

    153. 00402637     55                 push ebp                                   ; 继续F9运行程序后在此中断
    154. 00402638     56                 push esi
    155. 00402639     8DB3 30010000      lea esi,dword ptr ds:[ebx+130]
    156. 0040263F     6A 01              push 1

    157. 向上查找,来到004025D0处F2下断,继续F9运行,中断:

    158. 004025D0     64:A1 00000000     mov eax,dword ptr fs:[0]                   ; F2在此下断
    159. 004025D6     6A FF              push -1
    160. 004025D8     68 00874000        push Unpacked.00408700
    161. 004025DD     50                 push eax
    162. 004025DE     64:8925 00000000   mov dword ptr fs:[0],esp
    163. 004025E5     83EC 20            sub esp,20
    164. 004025E8     53                 push ebx
    165. 004025E9     57                 push edi
    166. 004025EA     8BD9               mov ebx,ecx
    167. 004025EC     6A 01              push 1
    168. 004025EE     E8 FF5B0000        call <jmp.&MFC42.#6334_CWnd::UpdateData>
    169. 004025F3     8B83 2C010000      mov eax,dword ptr ds:[ebx+12C]             ; 注册码
    170. 004025F9     8DBB 2C010000      lea edi,dword ptr ds:[ebx+12C]
    171. 004025FF     8A08               mov cl,byte ptr ds:[eax]                   ; 注册码第1位
    172. 00402601     80F9 50            cmp cl,50                                  ; 注册码第1位与0x50('P')比较
    173. 00402604     75 2A              jnz short Unpacked.00402630
    174. 00402606     8078 01 59         cmp byte ptr ds:[eax+1],59                 ; 注册码第2位与0x59('Y')比较
    175. 0040260A     75 24              jnz short Unpacked.00402630
    176. 0040260C     8078 02 47         cmp byte ptr ds:[eax+2],47                 ; 注册码第3位与0x47('G')比较
    177. 00402610     75 1E              jnz short Unpacked.00402630
    178. 00402612     8078 03 2D         cmp byte ptr ds:[eax+3],2D                 ; 注册码第4位与0x2D('-')比较
    179. 00402616     75 18              jnz short Unpacked.00402630
    180. 00402618     C743 60 B30D2F01   mov dword ptr ds:[ebx+60],12F0DB3
    181. 0040261F     8A48 2C            mov cl,byte ptr ds:[eax+2C]                ; 注册码第0x2D(45)位
    182. 00402622     80F9 20            cmp cl,20                                  ; 注册码第45位与0x20(' ')比较
    183. 00402625     75 10              jnz short Unpacked.00402637
    184. 00402627     C743 60 DA7D720C   mov dword ptr ds:[ebx+60],0C727DDA         ; 相等则对ds:[esi+60]处赋值0x0C727DDA
    185. 0040262E     EB 07              jmp short Unpacked.00402637
    186. 00402630     C743 60 F1CD3101   mov dword ptr ds:[ebx+60],131CDF1
    187. 00402637     55                 push ebp                                   ; 在此中断
    188. 00402638     56                 push esi
    189. 00402639     8DB3 30010000      lea esi,dword ptr ds:[ebx+130]
    190. 0040263F     6A 01              push 1                                    
    191. 00402641     8D4424 30          lea eax,dword ptr ss:[esp+30]
    192. 00402645     6A 00              push 0                                     ; 常数-0
    193. 00402647     50                 push eax
    194. 00402648     8BCE               mov ecx,esi
    195. 0040264A     E8 A95B0000        call <jmp.&MFC42.#4278_CString::Mid>       ; 取用户名第1位
    196. 0040264F     8BE8               mov ebp,eax
    197. 00402651     6A 01              push 1
    198. 00402653     8D4C24 2C          lea ecx,dword ptr ss:[esp+2C]
    199. 00402657     6A 14              push 14                                    ; 常数-0x14
    200. 00402659     51                 push ecx
    201. 0040265A     8BCF               mov ecx,edi
    202. 0040265C     C74424 44 00000000 mov dword ptr ss:[esp+44],0
    203. 00402664     E8 8F5B0000        call <jmp.&MFC42.#4278_CString::Mid>       ; 取注册码第21位
    204. 00402669     8B6D 00            mov ebp,dword ptr ss:[ebp]
    205. 0040266C     8B00               mov eax,dword ptr ds:[eax]
    206. 0040266E     55                 push ebp
    207. 0040266F     8B2D D8924000      mov ebp,dword ptr ds:[<&msvcrt._mbscmp>]   ; 比较是否相等
    208. 00402675     50                 push eax
    209. 00402676     C64424 40 01       mov byte ptr ss:[esp+40],1
    210. 0040267B     FFD5               call ebp
    211. 0040267D     83C4 08            add esp,8
    212. 00402680     85C0               test eax,eax
    213. 00402682     0F85 BB000000      jnz Unpacked.00402743                      ; 不等则Over
    214. 00402688     6A 01              push 1
    215. 0040268A     8D5424 20          lea edx,dword ptr ss:[esp+20]
    216. 0040268E     6A 02              push 2                                     ; 常数-2
    217. 00402690     52                 push edx
    218. 00402691     8BCE               mov ecx,esi
    219. 00402693     E8 605B0000        call <jmp.&MFC42.#4278_CString::Mid>       ; 取用户名第3位
    220. 00402698     894424 14          mov dword ptr ss:[esp+14],eax
    221. 0040269C     6A 01              push 1
    222. 0040269E     8D4424 1C          lea eax,dword ptr ss:[esp+1C]
    223. 004026A2     6A 19              push 19                                    ; 常数-0x19
    224. 004026A4     50                 push eax
    225. 004026A5     8BCF               mov ecx,edi
    226. 004026A7     C64424 44 02       mov byte ptr ss:[esp+44],2
    227. 004026AC     E8 475B0000        call <jmp.&MFC42.#4278_CString::Mid>       ; 取注册码第26位
    228. 004026B1     8B4C24 14          mov ecx,dword ptr ss:[esp+14]
    229. 004026B5     8B00               mov eax,dword ptr ds:[eax]
    230. 004026B7     8B09               mov ecx,dword ptr ds:[ecx]
    231. 004026B9     51                 push ecx
    232. 004026BA     50                 push eax
    233. 004026BB     FFD5               call ebp                                   ; 比较是否相等
    234. 004026BD     83C4 08            add esp,8
    235. 004026C0     8D4C24 18          lea ecx,dword ptr ss:[esp+18]
    236. 004026C4     85C0               test eax,eax
    237. 004026C6     0F944424 13        sete byte ptr ss:[esp+13]
    238. 004026CB     E8 48590000        call <jmp.&MFC42.#800_CString::~CString>
    239. 004026D0     8D4C24 1C          lea ecx,dword ptr ss:[esp+1C]
    240. 004026D4     C64424 38 01       mov byte ptr ss:[esp+38],1
    241. 004026D9     E8 3A590000        call <jmp.&MFC42.#800_CString::~CString>
    242. 004026DE     8A4424 13          mov al,byte ptr ss:[esp+13]
    243. 004026E2     84C0               test al,al
    244. 004026E4     74 5D              je short Unpacked.00402743                 ; 不等则Over
    245. 004026E6     6A 01              push 1
    246. 004026E8     8D5424 28          lea edx,dword ptr ss:[esp+28]
    247. 004026EC     6A 04              push 4                                     ; 常数-4
    248. 004026EE     52                 push edx
    249. 004026EF     8BCE               mov ecx,esi
    250. 004026F1     E8 025B0000        call <jmp.&MFC42.#4278_CString::Mid>       ; 取用户名第5位
    251. 004026F6     8BF0               mov esi,eax
    252. 004026F8     6A 01              push 1
    253. 004026FA     8D4424 24          lea eax,dword ptr ss:[esp+24]
    254. 004026FE     6A 24              push 24                                    ; 常数-0x24
    255. 00402700     50                 push eax
    256. 00402701     8BCF               mov ecx,edi
    257. 00402703     C64424 44 03       mov byte ptr ss:[esp+44],3
    258. 00402708     E8 EB5A0000        call <jmp.&MFC42.#4278_CString::Mid>       ; 取注册码第37位
    259. 0040270D     8B36               mov esi,dword ptr ds:[esi]
    260. 0040270F     8B00               mov eax,dword ptr ds:[eax]
    261. 00402711     56                 push esi
    262. 00402712     50                 push eax
    263. 00402713     FFD5               call ebp                                   ; 比较是否相等
    264. 00402715     83C4 08            add esp,8
    265. 00402718     8D4C24 20          lea ecx,dword ptr ss:[esp+20]
    266. 0040271C     85C0               test eax,eax
    267. 0040271E     0F944424 13        sete byte ptr ss:[esp+13]
    268. 00402723     E8 F0580000        call <jmp.&MFC42.#800_CString::~CString>
    269. 00402728     8D4C24 24          lea ecx,dword ptr ss:[esp+24]
    270. 0040272C     C64424 38 01       mov byte ptr ss:[esp+38],1
    271. 00402731     E8 E2580000        call <jmp.&MFC42.#800_CString::~CString>
    272. 00402736     8A4424 13          mov al,byte ptr ss:[esp+13]
    273. 0040273A     C64424 13 01       mov byte ptr ss:[esp+13],1
    274. 0040273F     84C0               test al,al
    275. 00402741     75 05              jnz short Unpacked.00402748
    276. 00402743     C64424 13 00       mov byte ptr ss:[esp+13],0
    277. 00402748     8D4C24 28          lea ecx,dword ptr ss:[esp+28]
    278. 0040274C     C64424 38 00       mov byte ptr ss:[esp+38],0
    279. 00402751     E8 C2580000        call <jmp.&MFC42.#800_CString::~CString>
    280. 00402756     8D4C24 2C          lea ecx,dword ptr ss:[esp+2C]
    281. 0040275A     C74424 38 FFFFFFFF mov dword ptr ss:[esp+38],-1
    282. 00402762     E8 B1580000        call <jmp.&MFC42.#800_CString::~CString>
    283. 00402767     8A4424 13          mov al,byte ptr ss:[esp+13]
    284. 0040276B     5E                 pop esi
    285. 0040276C     84C0               test al,al
    286. 0040276E     8B43 60            mov eax,dword ptr ds:[ebx+60]
    287. 00402771     5D                 pop ebp
    288. 00402772     74 07              je short Unpacked.0040277B                 ; 不等则Over
    289. 00402774     05 F1CD3101        add eax,131CDF1                            ; 若相等,则EAX=EAX+0x131CDF1
    290. 00402779     EB 05              jmp short Unpacked.00402780
    291. 0040277B     05 A25D4F00        add eax,4F5DA2
    292. 00402780     8BCB               mov ecx,ebx
    293. 00402782     8943 60            mov dword ptr ds:[ebx+60],eax              ; 将EAX的值存入ds:[esi+60]处
    294. 00402785     E8 D6580000        call <jmp.&MFC42.#2379_CWnd::Default>
    295. 0040278A     6A 00              push 0
    296. 0040278C     8BCB               mov ecx,ebx
    297. 0040278E     E8 5F5A0000        call <jmp.&MFC42.#6334_CWnd::UpdateData>
    298. 00402793     8B4C24 28          mov ecx,dword ptr ss:[esp+28]
    299. 00402797     5F                 pop edi
    300. 00402798     5B                 pop ebx
    301. 00402799     64:890D 00000000   mov dword ptr fs:[0],ecx
    302. 004027A0     83C4 2C            add esp,2C
    303. 004027A3     C2 0400            retn 4

    304. 通过以上代码可知:若用户名和注册码之间的关系符合以上要求,则EAX=0x0C727DDA+0x131CDF1=0x0DA44BCB,
    305. 然后将EAX的值存入ds:[esi+60]处,那么在00402586处对ds:[esi+60]的值和0x0DA44BCB比较则相等。

    306. -----------------------------------------------------------------------------------------------
    307. 【破解总结】
    308. 1.程序不太好下断点。通过调试知道,载入程序后,Ctrl+N,

    309. =================================================================
    310. 004091F4     UPX0        导入       MFC42.#6334_CWnd::UpdateData
    311. =================================================================

    312. 找到后下断,输入注册信息,中断后程序会异常,堆栈提示:

    313. =================================================================
    314. 返回到 Unpacked.004027BA 来自 <jmp.&MFC42.#6334_CWnd::UpdateData>
    315. =================================================================

    316. 根据堆栈提示也可以找到关键点。

    317. 2.用户名必须不小于5位,注册码必须为0x2D(45)位。
    318. 3.注册码前4位必须为:"PYG-",最后一位必须为" "(空格)
    319.   注册码第21位必须=用户名第1位
    320.   注册码第26位必须=用户名第3位
    321.   注册码第37位必须=用户名第5位
    322. 4.注册码(((第7位 xor 第6位)and 0x7F)*第8位+第5位)除以0x6B,余数必须为0
    323.   注册码((第11位 and 第10位)*第12位+第9位)除以0x65,余数必须为8
    324.   注册码((第15位 * 第14位)+第16位+第13位)除以0x69,余数必须为0
    325.   注册码((第19位 or 第18位)*第20位+第17位)除以0x69,余数必须为0
    326. 一组可用注册信息:

    327. ====================================================
    328. RegName:hrbxhui
    329. RegCode:PYG-aAj2&m93MRcdKhPHhPzFEbXbfVyH8pTWhuTYo2Qg
    330. ====================================================

    331. 暴破更改以下位置:

    332. 004024A9          jnz Unpacked.004025AE                      ; jnz====>NOP
    333. 004024DF          jnz Unpacked.004025AE                      ; jnz====>NOP
    334. 0040251D          jnz Unpacked.004025AE                      ; jnz====>NOP
    335. 00402550          jnz short Unpacked.004025AE                ; jnz====>NOP
    336. 00402581          jnz short Unpacked.004025AE                ; jnz====>NOP
    337. 0040258D          je short Unpacked.004025A7                 ; je=====>jmp

    338. 【VB注册机源码】

    339. '// 取得随机字符串
    340. Public Function GetRndString(ByVal lngNum As Long) As String
    341. If lngNum <= 0 Then Exit Function

    342. Dim i As Long
    343. Dim intLength As Integer
    344. Const STRINGSOURCE = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890"
    345. intLength = Len(STRINGSOURCE) - 1

    346. For i = 1 To lngNum
    347.     Randomize
    348.     GetRndString = GetRndString & Mid(STRINGSOURCE, Int(Rnd * intLength + 1), 1)
    349. Next
    350. End Function

    351. Private Sub btnGenerate_Click(ByVal ClickReason As b2kClickReason)

    352. Dim RegName As String
    353. Dim RegCode As String
    354. Dim TmpStr As String
    355. Dim Str1 As String
    356. Dim Str2 As String
    357. Dim Str3 As String
    358. Dim Str4 As String
    359. Dim Num1 As Integer
    360. Dim Num2 As Integer
    361. Dim Num3 As Integer
    362. Dim Num4 As Integer

    363. On Error Resume Next
    364. If Len(Text1.Text) < 5 Then
    365.      Text2.Text = "用户名长度太短!"
    366. Else
    367.     Str1 = " "
    368.     Str2 = " "
    369.     Str3 = " "
    370.     Str4 = " "
    371.     RegName = Text1.Text

    372.     Do While (Asc(Str1) < &H21 Or Asc(Str2) < &H21 Or Asc(Str3) < &H21 Or Asc(Str4) < &H21)
    373.         TmpStr = "PYG-" & GetRndString(16) & Mid(RegName, 1, 1) & _
    374.                           GetRndString(4) & Mid(RegName, 3, 1) & _
    375.                           GetRndString(10) & Mid(RegName, 5, 1) & _
    376.                           GetRndString(7)

    377.         Num1 = Asc(Mid(TmpStr, 6, 1))
    378.         Num2 = Asc(Mid(TmpStr, 7, 1))
    379.         Num3 = Asc(Mid(TmpStr, 8, 1))
    380.         Num4 = &H6B - ((((Num1 Xor Num2) And &H7F) * Num3) Mod &H6B)
    381.         Str1 = Chr(Num4)

    382.         Num1 = Asc(Mid(TmpStr, 10, 1))
    383.         Num2 = Asc(Mid(TmpStr, 11, 1))
    384.         Num3 = Asc(Mid(TmpStr, 12, 1))
    385.         Num4 = &H65 - (((Num1 And Num2) * Num3) Mod &H65) + 8
    386.         Str2 = Chr(Num4)

    387.         Num1 = Asc(Mid(TmpStr, 14, 1))
    388.         Num2 = Asc(Mid(TmpStr, 15, 1))
    389.         Num3 = Asc(Mid(TmpStr, 16, 1))
    390.         Num4 = &H69 - ((Num1 * Num2 + Num3) Mod &H69)
    391.         Str3 = Chr(Num4)

    392.         Num1 = Asc(Mid(TmpStr, 18, 1))
    393.         Num2 = Asc(Mid(TmpStr, 19, 1))
    394.         Num3 = Asc(Mid(TmpStr, 20, 1))
    395.         Num4 = &H69 - (((Num1 Or Num2) * Num3) Mod &H69)
    396.         Str4 = Chr(Num4)
    397.     Loop

    398.     RegCode = Mid(TmpStr, 1, 4) & Str1 & _
    399.           Mid(TmpStr, 6, 3) & Str2 & _
    400.           Mid(TmpStr, 10, 3) & Str3 & _
    401.           Mid(TmpStr, 14, 3) & Str4 & Mid(TmpStr, 18, 27) & " "
    402.     Text2 = RegCode
    403. End If
    404. End Sub

    405. -----------------------------------------------------------------------------------------------
    406. 【版权声明】本文纯属技术交流, 转载请注明作者并保持文章的完整, 谢谢!

    复制代码

    [ 本帖最后由 hrbx 于 2007-6-13 23:22 编辑 ]
    PYG19周年生日快乐!
  • TA的每日心情

    2016-6-2 20:34
  • 签到天数: 10 天

    [LV.3]偶尔看看II

    发表于 2007-6-13 13:42:40 | 显示全部楼层
    精彩~学习了!
    PYG19周年生日快乐!
  • TA的每日心情
    奋斗
    2016-10-21 20:30
  • 签到天数: 1 天

    [LV.1]初来乍到

     楼主| 发表于 2007-6-13 13:46:26 | 显示全部楼层
    RegName:hrbxhui
    RegCode:PYG-3sQ4m8DhcQJfP3SvhmhvGbXxitMGorUrhy8vXiig

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?加入我们

    x
    PYG19周年生日快乐!
  • TA的每日心情
    慵懒
    2018-6-6 15:51
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2007-6-13 13:49:33 | 显示全部楼层
    分析得很地道啊!注册机也做得好倩!
    PYG19周年生日快乐!
  • TA的每日心情
    开心
    2024-12-1 11:04
  • 签到天数: 12 天

    [LV.3]偶尔看看II

    发表于 2007-6-13 13:59:58 | 显示全部楼层
    Good Job!
    PYG19周年生日快乐!
  • TA的每日心情
    无聊
    2017-8-31 14:43
  • 签到天数: 7 天

    [LV.3]偶尔看看II

    发表于 2007-6-13 15:52:57 | 显示全部楼层
    看来真得和飘云老大说的一样,,考验耐心、、算法分析比较麻烦/:08   


    注册机比较好看的。。学习楼主的破文了,。。
    PYG19周年生日快乐!

    该用户从未签到

    发表于 2007-6-13 22:30:33 | 显示全部楼层
    这里说一下,我似乎记得idiv :商保存在AX里,余数保存在DX里

    楼主在上面说
    004024DB     F7F9               idiv ecx                                   ; EAX/ECX
    004024DD     85D2               test edx,edx                               ; EDX=商

    不知道是不是我记错了.
    PYG19周年生日快乐!
  • TA的每日心情
    奋斗
    2016-10-21 20:30
  • 签到天数: 1 天

    [LV.1]初来乍到

     楼主| 发表于 2007-6-13 23:23:07 | 显示全部楼层
    原帖由 网际座山雕 于 2007-6-13 22:30 发表
    这里说一下,我似乎记得idiv :商保存在AX里,余数保存在DX里

    楼主在上面说
    004024DB     F7F9               idiv ecx                                   ; EAX/ECX
    004024DD     85D2               test  ...



    谢谢 网际座山雕 指出,已更正,谢谢!
    PYG19周年生日快乐!
  • TA的每日心情
    开心
    2024-12-6 09:28
  • 签到天数: 121 天

    [LV.7]常住居民III

    发表于 2007-6-14 14:45:36 | 显示全部楼层
    收藏了,今晚来研究一下
    PYG19周年生日快乐!

    该用户从未签到

    发表于 2007-6-15 09:24:10 | 显示全部楼层
    强人,高手,学习!
    PYG19周年生日快乐!
    您需要登录后才可以回帖 登录 | 加入我们

    本版积分规则

    快速回复 返回顶部 返回列表