飘云阁

 找回密码
 加入我们

QQ登录

只需一步,快速开始

查看: 5313|回复: 7

Crack for Newbies Crackme v3.0算法分析

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

    [LV.1]初来乍到

    发表于 2006-7-30 11:06:14 | 显示全部楼层 |阅读模式

    1. 【破文标题】Crack for Newbies Crackme v3.0算法分析
    2. 破解作者】hrbx
    3. 【作者主页】hrbx.ys168.com
    4. 【作者邮箱】[email protected]
    5. 【破解平台】WinXP
    6. 【使用工具】flyOD1.10、Peid
    7. 【破解日期】2006-7-30
    8. 【软件名称】Crack for Newbies Crackme v3.0
    9. 【软件大小】515 K
    10. 【下载地址】https://www.chinapyg.com/viewthread.php?tid=6528&highlight=
    11. 【加壳方式】无
    12. 【软件简介】Crack for Newbies Crackme v3.0
    13. -----------------------------------------------------------------------------------------------
    14. 【破解声明】我是一只小菜鸟,偶得一点心得,愿与大家分享:)
    15. -----------------------------------------------------------------------------------------------
    16. 【破解过程】
    17. 1.查壳。用PEID扫描,显示为:Microsoft Visual C++ 6.0 [Overlay],实际上为易语言,软件无壳。
    18. 2.试运行。程序要求输入启动密码才能进入,进入后输入注册信息后点"注册"按钮,程序无错误提示。
    19. 3.找出启动密码。OD载入程序,F9运行,来到:

    20. 00403831 N>  55                push ebp                              ; OD载入暂停在这里
    21. 00403832     8BEC              mov ebp,esp
    22. 00403834     6A FF             push -1
    23. 00403836     68 F0624000       push Newbies_.004062F0

    24. Alt+M查看内存,找到:
    25. ----------------------------------------------------------------------------------------------
    26.   地址       大小             物主              区段        类型      初始访问   访问
    27. 00409000 00004000 (16384.) Newbies_ 00400000   .ecode   mag 01001002    RWE       R
    28. ----------------------------------------------------------------------------------------------

    29. 在.ecode段F2下断,输入启动密码后点“进入”按钮,立即中断:

    30. 0040C24F     55                push ebp                              ; 在此中断
    31. 0040C250     8BEC              mov ebp,esp
    32. 0040C252     81EC 08000000     sub esp,8
    33. 0040C258     6A FF             push -1
    34. 0040C25A     6A 08             push 8
    35. 0040C25C     68 06000116       push 16010006
    36. 0040C261     68 01000152       push 52010001
    37. 0040C266     E8 DD030000       call Newbies_.0040C648
    38. 0040C26B     83C4 10           add esp,10
    39. 0040C26E     8945 FC           mov dword ptr ss:[ebp-4],eax          ; 假码"9876543210"
    40. 0040C271     68 CB904000       push Newbies_.004090CB                ; ASCII "Can't open file!",启动密码
    41. 0040C276     FF75 FC           push dword ptr ss:[ebp-4]             ;
    42. 0040C279     E8 34FFFFFF       call Newbies_.0040C1B2                ; 真假码比较
    43. 0040C27E     83C4 08           add esp,8
    44. 0040C281     83F8 00           cmp eax,0
    45. 0040C284     B8 00000000       mov eax,0
    46. 0040C289     0F94C0            sete al
    47. 0040C28C     8945 F8           mov dword ptr ss:[ebp-8],eax
    48. 0040C28F     8B5D FC           mov ebx,dword ptr ss:[ebp-4]
    49. 0040C292     85DB              test ebx,ebx
    50. 0040C294     74 09             je short Newbies_.0040C29F
    51. 0040C296     53                push ebx
    52. 0040C297     E8 A0030000       call Newbies_.0040C63C
    53. 0040C29C     83C4 04           add esp,4
    54. 0040C29F     837D F8 00        cmp dword ptr ss:[ebp-8],0
    55. 0040C2A3     0F84 38000000     je Newbies_.0040C2E1                  ; 暴破点1,NOP掉
    56. 0040C2A9     68 02000080       push 80000002
    57. 0040C2AE     6A 00             push 0
    58. 0040C2B0     68 01000000       push 1
    59. 0040C2B5     6A 00             push 0
    60. 0040C2B7     6A 00             push 0
    61. 0040C2B9     6A 00             push 0
    62. 0040C2BB     68 01000100       push 10001
    63. 0040C2C0     68 04000106       push 6010004
    64. 0040C2C5     68 05000152       push 52010005
    65. 0040C2CA     68 03000000       push 3
    66. 0040C2CF     BB 20030000       mov ebx,320
    67. 0040C2D4     E8 69030000       call Newbies_.0040C642
    68. 0040C2D9     83C4 28           add esp,28
    69. 0040C2DC     E9 00000000       jmp Newbies_.0040C2E1
    70. 0040C2E1     8BE5              mov esp,ebp
    71. 0040C2E3     5D                pop ebp
    72. 0040C2E4     C3                retn

    73. 可以看出,启动密码即是:Can't open file!
    74. 4.追出注册码。输入启动密码后进入程序,输入注册信息:
    75. =============================
    76. 用户名:hrbx
    77. 注册码:9876543210
    78. =============================

    79. Alt+M查看内存,在.ecode段F2下断,点“注册”按钮,立即中断:

    80. 0040C30C     55                push ebp                           ; 在此中断
    81. 0040C30D     8BEC              mov ebp,esp
    82. 0040C30F     81EC 2C000000     sub esp,2C
    83. 0040C315     C745 FC 00000000  mov dword ptr ss:[ebp-4],0
    84. 0040C31C     C745 F8 00000000  mov dword ptr ss:[ebp-8],0
    85. 0040C323     C745 F4 00000000  mov dword ptr ss:[ebp-C],0
    86. 0040C32A     C745 F0 00000000  mov dword ptr ss:[ebp-10],0
    87. 0040C331     6A FF             push -1
    88. 0040C333     6A 08             push 8
    89. 0040C335     68 0C000116       push 1601000C
    90. 0040C33A     68 05000152       push 52010005
    91. 0040C33F     E8 04030000       call Newbies_.0040C648
    92. 0040C344     83C4 10           add esp,10
    93. 0040C347     8945 EC           mov dword ptr ss:[ebp-14],eax
    94. 0040C34A     8B45 EC           mov eax,dword ptr ss:[ebp-14]
    95. 0040C34D     50                push eax
    96. 0040C34E     8B5D FC           mov ebx,dword ptr ss:[ebp-4]
    97. 0040C351     85DB              test ebx,ebx
    98. 0040C353     74 09             je short Newbies_.0040C35E
    99. 0040C355     53                push ebx
    100. 0040C356     E8 E1020000       call Newbies_.0040C63C
    101. 0040C35B     83C4 04           add esp,4
    102. 0040C35E     58                pop eax
    103. 0040C35F     8945 FC           mov dword ptr ss:[ebp-4],eax       ; 用户名"hrbx"
    104. 0040C362     6A FF             push -1
    105. 0040C364     6A 08             push 8
    106. 0040C366     68 0C000116       push 1601000C
    107. 0040C36B     68 05000152       push 52010005
    108. 0040C370     E8 D3020000       call Newbies_.0040C648
    109. 0040C375     83C4 10           add esp,10
    110. 0040C378     8945 EC           mov dword ptr ss:[ebp-14],eax
    111. 0040C37B     68 04000080       push 80000004
    112. 0040C380     6A 00             push 0
    113. 0040C382     8B45 EC           mov eax,dword ptr ss:[ebp-14]
    114. 0040C385     85C0              test eax,eax
    115. 0040C387     75 05             jnz short Newbies_.0040C38E
    116. 0040C389     B8 DC904000       mov eax,Newbies_.004090DC
    117. 0040C38E     50                push eax
    118. 0040C38F     68 01000000       push 1
    119. 0040C394     BB 30010000       mov ebx,130
    120. 0040C399     E8 A4020000       call Newbies_.0040C642             ; 获取用户名长度
    121. 0040C39E     83C4 10           add esp,10
    122. 0040C3A1     8945 E8           mov dword ptr ss:[ebp-18],eax      ; 用户名长度保存,EAX=4
    123. 0040C3A4     8B5D EC           mov ebx,dword ptr ss:[ebp-14]
    124. 0040C3A7     85DB              test ebx,ebx
    125. 0040C3A9     74 09             je short Newbies_.0040C3B4
    126. 0040C3AB     53                push ebx
    127. 0040C3AC     E8 8B020000       call Newbies_.0040C63C
    128. 0040C3B1     83C4 04           add esp,4
    129. 0040C3B4     8B45 E8           mov eax,dword ptr ss:[ebp-18]
    130. 0040C3B7     8945 F8           mov dword ptr ss:[ebp-8],eax      
    131. 0040C3BA     8B45 F8           mov eax,dword ptr ss:[ebp-8]
    132. 0040C3BD     33C9              xor ecx,ecx
    133. 0040C3BF     50                push eax
    134. 0040C3C0     8D45 F4           lea eax,dword ptr ss:[ebp-C]
    135. 0040C3C3     8BD8              mov ebx,eax
    136. 0040C3C5     58                pop eax
    137. 0040C3C6     41                inc ecx
    138. 0040C3C7     51                push ecx
    139. 0040C3C8     53                push ebx
    140. 0040C3C9     890B              mov dword ptr ds:[ebx],ecx
    141. 0040C3CB     50                push eax
    142. 0040C3CC     3BC8              cmp ecx,eax
    143. 0040C3CE     0F8F 26010000     jg Newbies_.0040C4FA
    144. 0040C3D4     68 01030080       push 80000301
    145. 0040C3D9     6A 00             push 0
    146. 0040C3DB     FF75 F4           push dword ptr ss:[ebp-C]
    147. 0040C3DE     68 04000080       push 80000004
    148. 0040C3E3     6A 00             push 0
    149. 0040C3E5     8B45 FC           mov eax,dword ptr ss:[ebp-4]
    150. 0040C3E8     85C0              test eax,eax
    151. 0040C3EA     75 05             jnz short Newbies_.0040C3F1
    152. 0040C3EC     B8 DC904000       mov eax,Newbies_.004090DC
    153. 0040C3F1     50                push eax                           ; 用户名"hrbx"
    154. 0040C3F2     68 02000000       push 2
    155. 0040C3F7     BB 44010000       mov ebx,144
    156. 0040C3FC     E8 41020000       call Newbies_.0040C642             ; 依次取用户名每位字符的ASCII值
    157. 0040C401     83C4 1C           add esp,1C
    158. 0040C404     8945 EC           mov dword ptr ss:[ebp-14],eax      ; EAX=0x68('h')
    159. 0040C407     DB45 F0           fild dword ptr ss:[ebp-10]         ; 载入地址ss:[ebp-10]的值(初值为0),记为Sum
    160. 0040C40A     DD5D E4           fstp qword ptr ss:[ebp-1C]
    161. 0040C40D     DD45 E4           fld qword ptr ss:[ebp-1C]
    162. 0040C410     DB45 EC           fild dword ptr ss:[ebp-14]         ; 用户名每位字符的ASCII值用浮点数表示,记为N
    163. 0040C413     DD5D DC           fstp qword ptr ss:[ebp-24]
    164. 0040C416     DC45 DC           fadd qword ptr ss:[ebp-24]         ; Sum=Sum+N
    165. 0040C419     DD5D D4           fstp qword ptr ss:[ebp-2C]         ; st=104.0
    166. 0040C41C     DD45 D4           fld qword ptr ss:[ebp-2C]
    167. 0040C41F     E8 C1FEFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    168. 0040C424     8945 F0           mov dword ptr ss:[ebp-10],eax      ; EAX=0x68(104)
    169. 0040C427     DB45 F0           fild dword ptr ss:[ebp-10]
    170. 0040C42A     DD5D E8           fstp qword ptr ss:[ebp-18]
    171. 0040C42D     DD45 E8           fld qword ptr ss:[ebp-18]          ; ss:[0012EAA8]=104.0
    172. 0040C430     DC0D DD904000     fmul qword ptr ds:[4090DD]         ; 取完低8位乘以固定数N1,Sum=Sum*N1
    173. 0040C436     DD5D E0           fstp qword ptr ss:[ebp-20]         ; 固定数N1=ds:[004090DD]=108.0
    174. 0040C439     DD45 E0           fld qword ptr ss:[ebp-20]          ; st=11232.0
    175. 0040C43C     E8 A4FEFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    176. 0040C441     8945 F0           mov dword ptr ss:[ebp-10],eax      ; EAX=0x2BE0(11232)
    177. 0040C444     DB45 F0           fild dword ptr ss:[ebp-10]
    178. 0040C447     DD5D E8           fstp qword ptr ss:[ebp-18]
    179. 0040C44A     DD45 E8           fld qword ptr ss:[ebp-18]
    180. 0040C44D     DC0D E5904000     fmul qword ptr ds:[4090E5]         ; 取完低8位乘以固定数N2,Sum=Sum*N2
    181. 0040C453     DD5D E0           fstp qword ptr ss:[ebp-20]         ; 固定数N2=ds:[004090E5]=101.0
    182. 0040C456     DD45 E0           fld qword ptr ss:[ebp-20]          ; st=1134432.0
    183. 0040C459     E8 87FEFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    184. 0040C45E     8945 F0           mov dword ptr ss:[ebp-10],eax      ; eax=0x114F60(1134432)
    185. 0040C461     DB45 F0           fild dword ptr ss:[ebp-10]
    186. 0040C464     DD5D E8           fstp qword ptr ss:[ebp-18]
    187. 0040C467     DD45 E8           fld qword ptr ss:[ebp-18]
    188. 0040C46A     DC0D ED904000     fmul qword ptr ds:[4090ED]         ; 取完低8位乘以固定数N3,Sum=Sum*N3
    189. 0040C470     DD5D E0           fstp qword ptr ss:[ebp-20]         ; 固定数N3=ds:[004090ED]=110.0
    190. 0040C473     DD45 E0           fld qword ptr ss:[ebp-20]          ; st=124787520.0
    191. 0040C476     E8 6AFEFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    192. 0040C47B     8945 F0           mov dword ptr ss:[ebp-10],eax      ; EAX=0x7701B40(124787520)
    193. 0040C47E     DB45 F0           fild dword ptr ss:[ebp-10]
    194. 0040C481     DD5D E8           fstp qword ptr ss:[ebp-18]
    195. 0040C484     DD45 E8           fld qword ptr ss:[ebp-18]
    196. 0040C487     DC0D F5904000     fmul qword ptr ds:[4090F5]         ; 取完低8位乘以固定数N4,Sum=Sum*N4
    197. 0040C48D     DD5D E0           fstp qword ptr ss:[ebp-20]         ; 固定数N4=ds:[004090F5]=103.0
    198. 0040C490     DD45 E0           fld qword ptr ss:[ebp-20]          ; st=1.2853114560000000000e+10
    199. 0040C493     E8 4DFEFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    200. 0040C498     8945 F0           mov dword ptr ss:[ebp-10],eax      ; EAX=0xFE1AF6C0
    201. 0040C49B     DB45 F0           fild dword ptr ss:[ebp-10]
    202. 0040C49E     DD5D E8           fstp qword ptr ss:[ebp-18]
    203. 0040C4A1     DD45 E8           fld qword ptr ss:[ebp-18]
    204. 0040C4A4     DC0D FD904000     fmul qword ptr ds:[4090FD]         ; 取完低8位乘以固定数N5,Sum=Sum*N5
    205. 0040C4AA     DD5D E0           fstp qword ptr ss:[ebp-20]         ; 固定数N5=ds:[004090FD]=120.0
    206. 0040C4AD     DD45 E0           fld qword ptr ss:[ebp-20]          ; st=-3814479360.0
    207. 0040C4B0     E8 30FEFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    208. 0040C4B5     8945 F0           mov dword ptr ss:[ebp-10],eax      ; EAX=0x1CA3AA00
    209. 0040C4B8     DB45 F0           fild dword ptr ss:[ebp-10]
    210. 0040C4BB     DD5D E8           fstp qword ptr ss:[ebp-18]
    211. 0040C4BE     DD45 E8           fld qword ptr ss:[ebp-18]
    212. 0040C4C1     DC0D 05914000     fmul qword ptr ds:[409105]         ; 取完低8位乘以固定数N6,Sum=Sum*N6
    213. 0040C4C7     DD5D E0           fstp qword ptr ss:[ebp-20]         ; 固定数N6=ds:[00409105]=117.0
    214. 0040C4CA     DD45 E0           fld qword ptr ss:[ebp-20]          ; st=5.6217088512000000000e+10
    215. 0040C4CD     E8 13FEFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    216. 0040C4D2     8945 F0           mov dword ptr ss:[ebp-10],eax      ; EAX=0x16CCB200
    217. 0040C4D5     DB45 F0           fild dword ptr ss:[ebp-10]
    218. 0040C4D8     DD5D E8           fstp qword ptr ss:[ebp-18]
    219. 0040C4DB     DD45 E8           fld qword ptr ss:[ebp-18]
    220. 0040C4DE     DC0D E5904000     fmul qword ptr ds:[4090E5]         ; 取完低8位乘以固定数N7,Sum=Sum*N7
    221. 0040C4E4     DD5D E0           fstp qword ptr ss:[ebp-20]         ; 固定数N7=ds:[004090E5]=101.0
    222. 0040C4E7     DD45 E0           fld qword ptr ss:[ebp-20]          ; st=3.8633880064000000000e+10
    223. 0040C4EA     E8 F6FDFFFF       call Newbies_.0040C2E5             ; 取运算结果的低8位
    224. 0040C4EF     8945 F0           mov dword ptr ss:[ebp-10],eax      ; EAX=0xFEC23A00
    225. 0040C4F2     58                pop eax
    226. 0040C4F3     5B                pop ebx
    227. 0040C4F4     59                pop ecx
    228. 0040C4F5   ^ E9 CCFEFFFF       jmp Newbies_.0040C3C6
    229. 0040C4FA     83C4 0C           add esp,0C
    230. 0040C4FD     837D F8 01        cmp dword ptr ss:[ebp-8],1
    231. 0040C501     0F8C B4000000     jl Newbies_.0040C5BB
    232. 0040C507     68 01030080       push 80000301
    233. 0040C50C     6A 00             push 0
    234. 0040C50E     FF75 F0           push dword ptr ss:[ebp-10]         ; 运算结果ss:[ebp-10]=0x27899E00(663330304)
    235. 0040C511     68 01000000       push 1
    236. 0040C516     BB 68010000       mov ebx,168
    237. 0040C51B     E8 22010000       call Newbies_.0040C642             ; 运算结果转为字符串"663330304"
    238. 0040C520     83C4 10           add esp,10
    239. 0040C523     8945 EC           mov dword ptr ss:[ebp-14],eax
    240. 0040C526     6A FF             push -1
    241. 0040C528     6A 08             push 8
    242. 0040C52A     68 10000116       push 16010010
    243. 0040C52F     68 05000152       push 52010005
    244. 0040C534     E8 0F010000       call Newbies_.0040C648
    245. 0040C539     83C4 10           add esp,10
    246. 0040C53C     8945 E8           mov dword ptr ss:[ebp-18],eax      ; 假码"9876543210"
    247. 0040C53F     8B45 EC           mov eax,dword ptr ss:[ebp-14]      ; 真码"663330304"
    248. 0040C542     50                push eax
    249. 0040C543     FF75 E8           push dword ptr ss:[ebp-18]
    250. 0040C546     E8 67FCFFFF       call Newbies_.0040C1B2             ; 真假码比较
    251. 0040C54B     83C4 08           add esp,8
    252. 0040C54E     83F8 00           cmp eax,0
    253. 0040C551     B8 00000000       mov eax,0
    254. 0040C556     0F94C0            sete al
    255. 0040C559     8945 E4           mov dword ptr ss:[ebp-1C],eax
    256. 0040C55C     8B5D E8           mov ebx,dword ptr ss:[ebp-18]
    257. 0040C55F     85DB              test ebx,ebx
    258. 0040C561     74 09             je short Newbies_.0040C56C
    259. 0040C563     53                push ebx
    260. 0040C564     E8 D3000000       call Newbies_.0040C63C
    261. 0040C569     83C4 04           add esp,4
    262. 0040C56C     8B5D EC           mov ebx,dword ptr ss:[ebp-14]
    263. 0040C56F     85DB              test ebx,ebx
    264. 0040C571     74 09             je short Newbies_.0040C57C
    265. 0040C573     53                push ebx
    266. 0040C574     E8 C3000000       call Newbies_.0040C63C
    267. 0040C579     83C4 04           add esp,4
    268. 0040C57C     837D E4 00        cmp dword ptr ss:[ebp-1C],0
    269. 0040C580     0F84 30000000     je Newbies_.0040C5B6               ; 暴破点2,改为NOP
    270. 0040C586     6A 00             push 0
    271. 0040C588     6A 00             push 0
    272. 0040C58A     6A 00             push 0
    273. 0040C58C     68 01030080       push 80000301
    274. 0040C591     6A 00             push 0
    275. 0040C593     68 00000000       push 0
    276. 0040C598     68 04000080       push 80000004
    277. 0040C59D     6A 00             push 0
    278. 0040C59F     68 0D914000       push Newbies_.0040910D             ; 注册成功提示 "Well done!"
    279. 0040C5A4     68 03000000       push 3
    280. 0040C5A9     BB 00030000       mov ebx,300
    281. 0040C5AE     E8 8F000000       call Newbies_.0040C642
    282. 0040C5B3     83C4 28           add esp,28
    283. 0040C5B6     E9 05000000       jmp Newbies_.0040C5C0
    284. 0040C5BB     E8 14000000       call Newbies_.0040C5D4
    285. 0040C5C0     8B5D FC           mov ebx,dword ptr ss:[ebp-4]
    286. 0040C5C3     85DB              test ebx,ebx
    287. 0040C5C5     74 09             je short Newbies_.0040C5D0
    288. 0040C5C7     53                push ebx
    289. 0040C5C8     E8 6F000000       call Newbies_.0040C63C
    290. 0040C5CD     83C4 04           add esp,4
    291. 0040C5D0     8BE5              mov esp,ebp
    292. 0040C5D2     5D                pop ebp
    293. 0040C5D3     C3                retn

    294. -----------------------------------------------------------------------------------------------
    295. 【破解总结】
    296. 1.程序启动密码为:Can't open file!
    297. 2.程序内置7个固定数,分别为:N1=108,N2=101,N1=110,N1=103,N1=120,N1=117,N1=101。
    298. 3.地址ss:[ebp-10]的值(初值为0),记为Sum,依次取用户名每位字符的ASCII值记为N,Sum=Sum+N,
    299. 取加法结果低8位乘以固定数N1,取乘法结果低8位后再乘以固定数N2,重复运算直到乘完固定数N7,结果保存
    300. 在地址ss:[ebp-10]中,用于用户名下一位字符的运算,运算最终结果以10进制整数表示转为字符串即为注册码。
    301. 一中可用注册信息:
    302. =============================
    303. 用户名:hrbx
    304. 注册码:663330304
    305. =============================

    306. 暴破更改以下位置:

    307. 0040C2A3             je Newbies_.0040C2E1           ; je====>NOP
    308. 0040C580             je Newbies_.0040C5B6           ; je====>NOP

    309. 【VB注册机源码】

    310. Function Low(num As Double) As Double   '自定义取低8位函数
    311. Dim Tmp As Double
    312. If (num > (2 ^ 32)) Or (num < -(2 ^ 32)) Then
    313.    Tmp = num / &HFFFFFFF
    314.    Tmp = Int(Tmp / &H10)
    315.    Tmp = Tmp * (2 ^ 32)
    316.    Low = num - Tmp
    317. Else
    318.    Low = num
    319. End If

    320. End Function

    321. Private Sub Generate_Click()
    322. Dim Name As String
    323. Dim Sum As Double
    324. Dim i As Long
    325. Dim Tmp As Long
    326. Dim ByteAry() As Byte

    327. On Error Resume Next

    328. If Text1.Text = "" Then
    329.      Text2.Text = "请输入用户名!"
    330. Else

    331.      Name = Trim(Text1.Text)
    332.      Sum = 0

    333.     ByteAry = StrConv(Name, vbFromUnicode)
    334.     For i = LBound(ByteAry) To UBound(ByteAry)
    335.         If ByteAry(i) > 128 Or ByteAry(i) < 0 Then
    336.            Tmp = ByteAry(i) - 256
    337.            Sum = Low(Sum + Tmp)
    338.            Sum = Low(Sum * 108)
    339.            Sum = Low(Sum * 101)
    340.            Sum = Low(Sum * 110)
    341.            Sum = Low(Sum * 103)
    342.            Sum = Low(Sum * 120)
    343.            Sum = Low(Sum * 117)
    344.            Sum = Low(Sum * 101)
    345.    
    346.         Else
    347.            Tmp = ByteAry(i)
    348.            Sum = Low(Sum + Tmp)
    349.            Sum = Low(Sum * 108)
    350.            Sum = Low(Sum * 101)
    351.            Sum = Low(Sum * 110)
    352.            Sum = Low(Sum * 103)
    353.            Sum = Low(Sum * 120)
    354.            Sum = Low(Sum * 117)
    355.            Sum = Low(Sum * 101)
    356.    
    357.          End If
    358.    
    359.      Next i
    360.      If (Sum > (2 ^ 31) Or Sum < -(2 ^ 31)) Then Sum = Low(Sum - 2 ^ 32)
    361.      Text2.Text = Sum

    362. End If

    363. End Sub

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

    复制代码

    [ 本帖最后由 hrbx 于 2006-7-30 11:50 编辑 ]

    本帖子中包含更多资源

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

    x
    PYG19周年生日快乐!

    该用户从未签到

    发表于 2006-7-30 12:05:41 | 显示全部楼层
    注册机做的好花哨
    PYG19周年生日快乐!

    该用户从未签到

    发表于 2006-7-30 13:41:56 | 显示全部楼层
    厉害,学习。。。。。。。。。。
    PYG19周年生日快乐!

    该用户从未签到

    发表于 2006-7-30 14:38:45 | 显示全部楼层

    29A 8#浮点指令教程(FPU instructions tutorial)

    来源:29A第8期
    翻译:nbw nbwo.blogbus.com
    注:
    翻译的不好,有些地方没弄明白,没敢翻译,有些地方不翻译了(cos,sin)。翻译这东西主要为了自己熟悉一下,因为看一遍实在体会不深刻。
    既然出于这目的,我也不能保证翻译的正确性,希望大家原谅!

    你或许想为什么要写或者读一篇关于FPU指令的教程,如果你认为这对写病毒没什么帮助,也无助于改善生活,那么你就想错了。
    这些指令会有很大帮助。

    顾名生义,浮点指令不仅支持整数,也支持十进制小数。相信我这些指令可以帮你躲避杀毒软件的检测(效果也不错:))。怎么实现呢?

    只需在加密/解密部分或者变形引擎中利用它们处理一下。因为半数的杀毒软件在检测这些指令时会挂起或者忽略这些文件,这样你就可以
    隐藏自己。

    现在我们开始正题:

    首先应该检测一下你的系统是否支持FPU指令集。也就是检查一下是否配备了协处理器。这个可以通过一条简单的指令来监测:SMSW EAX
    检查一下低位,为1,则有协处理器支持,否则我们可以跑去看电影了。

    看一下协处理器,如果处理器位386,486,586....,那么协处理器为387,487,587....以及相应的FPIs。

    现在看一下IEEE标准754标准文档,这些是用FPU处理浮点数据的Intel标准文档。

    指令格式如下:
    S-Sign, E-Exponent, F-Fraction 或简单表达为: S,E,F.
    S的长度为1bit(定点为0,否则为1)。F的长度为:总长度-E长度-1。

    一般浮点数表达形式为:S,2^E*F

    这里,FPU为我们提供了专门的“堆栈”来进行计算或者保存数据等操作,包括:
    ST(0), ST(1), ST(2),....ST(9)
    ST(0)也可以称为ST。相关操作执行时,这些堆栈用来存放浮点数据。

    现在看一下操作数的载入过程。当第一次载入时候,数据被存放在ST,以后每次操作,堆栈上升,开始被载入的操作数也随之上移,
    直到ST(9)。比如:
    load a : ST(0) = a; ST(1) = 0; ST(2) = 0.....
    load b : ST(0) = b; ST(1) = a; ST(2) = 0.....
    load c : ST(0) = c; ST(1) = b; ST(2) = a.....
    希望这里已经把事情讲明白了。
    最常用到的寄存器是ST(0)和ST(1)。
    下面是从文档中查到的FPU指令表。

    谀哪哪哪哪哪哪哪哪哪哪哪哪哪哪?
    ? 数据转移和常量 ?
    滥哪哪哪哪哪哪哪哪哪哪哪哪哪哪?

    FLD src 装载实数: st(0) = src (mem32/mem64/mem80)
    FILD src 装载整数: st(0) = src (mem16/mem32/mem64)
    FBLD src 装载BCD: st(0) = src (mem80)

    FLDZ 清零: st(0) = 0.0
    FLD1 置1: st(0) = 1.0
    FLDPI 载入圆周率: st(0) = ?(ie, pi)
    FLDL2T 载入 log2(10): st(0) = log2(10)
    FLDL2E 载入 log2(e): st(0) = log2(e)
    FLDLG2 载入 log10(2): st(0) = log10(2)
    FLDLN2 载入 loge(2): st(0) = loge(2)

    FST dest 保存实数: dest = st(0) (mem32/mem64)
    FSTP dest dest = st(0) (mem32/mem64/mem80) and pop stack
    FIST dest 保存整数: dest = st(0) (mem32/mem64)
    FISTP dest dest = st(0) (mem16/mem32/mem64) and pop stack
    FBST dest 保存 BCD: dest = st(0) (mem80)
    FBSTP dest dest = st(0) (mem80) and pop stack

    谀哪哪哪哪?
    ? 比较 ?
    滥哪哪哪哪?

    FCOM 比较实数: Set flags as for st(0) - st(1)
    FCOM op 设定st(0)的标记 - op (mem32/mem64)
    FCOMP op 比较 st(0) 和 op (reg/mem); 然后出栈
    FCOMPP 比较 st(0) 和 st(1) 并出栈操作2次
    FICOM op 比较整数: 设置st(0)标记 - op (mem16/mem32)
    FICOMP op 比较 st(0) 和 op (mem16/mem32) 并出栈

    FTST 判零操作: 比较 st(0) 是否为 0.0

    FUCOM st(i) 无序比较: st(0) to st(i) [486]
    FUCOMP st(i) 比较 st(0) 和 st(i) 并出栈
    FUCOMPP st(i) 比较 st(0) 和 st(i) 并出栈2次

    FXAM 检查: st(0) (设置条件代码)(译:我也不懂)

    谀哪哪哪哪哪目
    ? 运算 ?
    滥哪哪哪哪哪馁

    FADD 加实数: st(0) = st(0) + st(1)
    FADD src st(0) = st(0) + src (mem32/mem64)
    FADD st(i),st st(i) = st(i) + st(0)
    FADDP st(i),st st(i) = st(i) + st(0) and pop stack
    FIADD src 加整数: st(0) = st(0) + src (mem16/mem32)

    FSUB 减实数: st(0) = st(0) - st(1)
    FSUB src st(0) = st(0) - src (reg/mem)
    FSUB st(i),st st(i) = st(i) - st(0)
    FSUBP st(i),st st(i) = st(i) - st(0) and pop stack
    FSUBR st(i),st 减去保留数: st(0) = st(i) - st(0)
    FSUBRP st(i),st st(0) = st(i) - st(0); pop stack
    FISUB src 减去整数: st(0) = st(0) - src (mem16/mem32)
    FISUBR src 减去保留的整数: st(0) = src - st(0) (mem16/mem32)

    FMUL 乘以实数: st(0) = st(0) * st(1)
    FMUL st(i) st(0) = st(0) * st(i)
    FMUL st(i),st st(i) = st(0) * st(i)
    FMULP st(i),st st(i) = st(0) * st(i) and pop stack
    FIMUL src 乘以整数: st(0) = st(0) * src (mem16/mem32)

    FDIV 除以实数: st(0) = st(0) ?st(1)
    FDIV st(i) st(0) = st(0) ?t(i)
    FDIV st(i),st st(i) = st(0) ?st(i)
    FDIVP st(i),st st(i) = st(0) ?st(i) and pop stack
    FIDIV src 除以整数: st(0) = st(0) ?src (mem16/mem32)
    FDIVR st(i),st 除以保留的实数: st(0) = st(i) ?st(0)
    FDIVRP st(i),st st(0) = st(i) ?st(0) and pop stack(译:除法操作后有出栈操作)
    FIDIVR src 除以保留的整数: st(0) = src ?st(0) (mem16/mem32)

    FSQRT 开方: st(0) = sqrt st(0)

    FSCALE 求2的幂: st(0) = 2 ^ st(0)

    FXTRACT Extract exponent: st(0) = exponent of st(0) and gets pushed
    as st(0) = significand of st(0)

    FPREM Partial remainder: st(0) = st(0) MOD st(1)
    FPREM1 Partial Remainder (IEEE): same as FPREM, but in IEEE standard [486]

    FRNDINT Round to nearest int: st(0) = INT( st(0) ), depends on RC flag

    FABS Get absolute value: st(0) = ABS( st(0) ), removes sign (changes to postive)
    FCHS Change sign: st(0) = -st(0)

    谀哪哪哪哪哪哪哪目
    ?Transcendental ?
    滥哪哪哪哪哪哪哪馁

    FCOS Cosine: st(0) = COS( st(0) )
    FPTAN Partial tangent: st(0) = TAN( st(0) )
    FPATAN. Partial Arctangent: st(0) = ATAN( st(0) )
    FSIN Sine: st(0) = SIN( st(0) )
    FSINCOS Sine and Cosine: st(0) = SIN( st(0) ) and is pushed to st(1)
    st(0) = COS( st(0) )

    F2XM1 Calculate (2 ^ x)-1: st(0) = [2 ^ st(0)] - 1

    FYL2X Calculate Y * log2(X): st(0) is Y, st(1) is X; this replaces st(0) and
    st(1) with: st(0) * log2( st(1) )

    FYL2XP1 Calculate Y * log2(X+1): st(0) is Y; st(1) is X; this replaces st(0)
    and st(1) with: st(0) * log2( st(1)+1 )

    谀哪哪哪哪哪哪哪哪哪?
    ?Processor Control ?
    滥哪哪哪哪哪哪哪哪哪?

    FINIT 初始化FPU
    FSTSW AX STore Status Word in EAX., ie. EAX = MSW
    FSTSW dest dest = MSW (mem16)

    FLDCW src LoaD Control Word: FPU CW = src (mem16)
    FSTCW dest STore Control Word: dest = FPU CW

    FCLEX Clear exceptions

    FSTENV dest STore ENVironment: stores status, control and tag words
    and exception pointers into memory at dest

    FLDENV src LoaD ENVironment: loads environment from memory at src

    FSAVE dest Store FPU state: store FPU state into 94-bytes at dest

    FRSTOR src Load FPU state: restore FPU state as saved by FSAVE

    FINCSTP Increment FPU stack ptr: st(6)<-st(5); st(5)<-st(4),...,st(0)

    FDECSTP Decrement FPU stack ptr: st(0)<-st(1); st(1)<-st(2),...,st(7)
    The above 2 instuctions put the corresponding values too in the
    inc/dec stacks.

    FFREE st(i) Mark reg st(i) as unused

    FNOP No operation: st(0) = st(0), equivalent to nop.

    WAIT/FWAIT Synchronize FPU & CPU: Halt CPU until FPU finishes current opcode.

    FXCH - eXCHange instruction st(0) <- st(1)
    st(1) <- st(0) similar to xchg.

    假设我们需要做以下操作:

    tan(cos(sin(a*b+c*d)))/4

    需要做的很简单,具体如下:

    首先,需要知道,在数据载入以前,首先采用FILD初始化,因为按照IEEE354文档,FLD需要一个整数。
    我想说的是,假设你需要将变量VAR初始化为12345678h,那么,当使用FLD VAR获取类似于1.2345e-67
    (很恐怖?)。但是如果你使用FILD指令,VAR被载入12345678h,并且这也是我们需要的。

    下面看一下具体代码:

    finit ;该句非常必要
    fild dword ptr [a] ;ST(0) = a, dwords形式
    fild dword ptr ;ST(0) = b, ST(1) = a
    fadd ;ST(0) = a+b
    fistp dword ptr [Var] ;Var=ST(0), 存放在临时变量中
    fild dword ptr [c] ;ST(0) = c
    fild dword ptr [d] ;ST() = d, ST(1) = c
    fadd ;ST(0) = c+d
    fild dword ptr [Var] ;ST(0) = Var, ST(1) = c+d
    fmul ;ST(0) = Var*(c+d)
    fsin ;sin of ST(0)
    fcos ;cos of ST(0)
    ftan ;tan of ST(0)
    mov Var2, 4h ;Var2 = 4
    fild dword ptr [Var2] ;ST(0) = Var2 = 4, ST(1) = tan(cos(sin(a*b+c*d)))/4
    很简单,也很长?
    另外需要注意的地方是,需要指定.387(或者.487,.587)。
    比如:
    .386
    .387
    .data
    [...]
    .code
    [...]
    End
    这些指定声明了对32位FPU寄存器的使用。

    如果有问题,请联系:[email protected]

    -Surya/powerdryv
    -23rd June, 2004

    译者备注:
    最下面举例,计算:

    tan(cos(sin(a*b+c*d)))/4

    作者的代码:

    finit ;thats very very necesarry
    fild dword ptr [a] ;ST(0) = a, we work in dwords
    fild dword ptr ;ST(0) = b, ST(1) = a
    fadd ;ST(0) = a+b

    ;这句应该是fmul


    fistp dword ptr [Var] ;Var=ST(0), store in a temp. variable
    fild dword ptr [c] ;ST(0) = c




    fild dword ptr [d] ;ST() = d, ST(1) = c

    ;应为“ST(0) = d,”


    fadd ;ST(0) = c+d

    ;这句应该是fmul


    fild dword ptr [Var] ;ST(0) = Var, ST(1) = c+d
    fmul ;ST(0) = Var*(c+d)
    fsin ;sin of ST(0)
    fcos ;cos of ST(0)
    ftan ;tan of ST(0)
    mov Var2, 4h ;Var2 = 4
    fild dword ptr [Var2] ;ST(0) = Var2 = 4, ST(1) = tan(cos(sin(a*b+c*d)))/4


    我不懂fpu,或许说的不对。。

    29A出此文,让人有些郁闷,真有凑文之嫌
    PYG19周年生日快乐!
  • TA的每日心情
    奋斗
    2016-1-14 00:02
  • 签到天数: 138 天

    [LV.7]常住居民III

    发表于 2006-7-30 23:08:01 | 显示全部楼层
    算法蛮复杂的.1
    PYG19周年生日快乐!

    该用户从未签到

    发表于 2006-7-31 10:52:24 | 显示全部楼层
    兄弟好强!!!
    能给偶这样的菜鸟解释下你是怎么看出来是易的吗??
    还有,为什么在.ecode段下断啊??
    PYG19周年生日快乐!
  • TA的每日心情
    奋斗
    2016-10-21 20:30
  • 签到天数: 1 天

    [LV.1]初来乍到

     楼主| 发表于 2006-7-31 12:15:41 | 显示全部楼层
    1.用OD载入后ALT+M查看可以看到.ecode段,就差不多可以确定是易语言编写的了。
    运行程序后在堆栈区可以看见像:0012FC70   |100EDB10   krnln.100EDB10这样的信息就可以肯定是易语言的程序了。
    2.易语言程序下断.ecode段,经常可以断在核心处。

    [ 本帖最后由 hrbx 于 2006-7-31 12:19 编辑 ]
    PYG19周年生日快乐!

    该用户从未签到

    发表于 2006-7-31 12:28:03 | 显示全部楼层
    原帖由 hrbx 于 2006-7-31 12:15 发表
    1.用OD载入后ALT+M查看可以看到.ecode段,就差不多可以确定是易语言编写的了。
    运行程序后在堆栈区可以看见像:0012FC70   |100EDB10   krnln.100EDB10这样的信息就可以肯定是易语言的程序了。
    2.易语言程序下断 ...



    多谢兄弟指点~~~
    有学习拉 `~~
    好想再多给兄弟多加几分,可惜没有那个权利,呵呵~~
    PYG19周年生日快乐!
    您需要登录后才可以回帖 登录 | 加入我们

    本版积分规则

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