吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 4461|回复: 2
收起左侧

[原创] 【原创】WinCHM v5.01分析

[复制链接]
lacoucou 发表于 2015-4-6 01:47
本帖最后由 lacoucou 于 2015-4-6 01:51 编辑

【文章标题】WinCHM v5.01分析
【文章作者】lacoucou
【软件名称】WinCHM
【软件大小】6.66 MB
【原版下载】http://www.softany.com/winchm/download.htm
【保护方式】序列号
【软件简介】WinCHM是一款简单易用的html帮助制作软件.
【作者声明】本文仅供研究学习,本人对因这篇文章而导致的一切后果,不承担任何法律责任。本文中的不足之处请各位多多指教。
【分析过程】
[大体简介]
这个软件结构比较简单, Delphi写的 . 注册机制是: 十五天的试用时间,十五天之内可以使用软件,但是在生成的chm文件标题上会有没有注册字样。过了十五天没注册就没法使用。
注册算法:根据注册码算出一个固定值然后跟存好的值比较来判断版本。
注册信息保存位置:
HKEY_CURRENT_USER\Software\Softany\winchm 下边。
不过判断部分太失败了, 竟然是明码比较的方式, 当然为了不太扫兴, 我大概分析了下整个程序的算法.

分析过程:
运行程序会显示15days left...这样的提示。点击注册按钮有错误提示。Illegal registration code!
IDA搜索字符串。

往上边一找就找到关键点:
代码:
[Asm] 纯文本查看 复制代码
0057179C  |.  A1 0C265E00   MOV EAX,DWORD PTR DS:[0x5E260C]
005717A1  |.  8338 00       CMP DWORD PTR DS:[EAX],0x0
005717A4  |.  74 57         JE SHORT winchm.005717FD                 ;  关键跳
005717A6  |.  8B0D 0C265E00 MOV ECX,DWORD PTR DS:[0x5E260C]          ;  winchm.005E84E8
005717AC  |.  8B09          MOV ECX,DWORD PTR DS:[ECX]
005717AE  |.  8D45 FC       LEA EAX,[LOCAL.1]
005717B1  |.  BA 58185700   MOV EDX,winchm.00571858                  ;  UNICODE "Thank you for purchasing our product!\r\n\r\nLicense type: "
005717B6  |.  E8 BD5AE9FF   CALL winchm.00407278
005717BB  |.  A1 902A5E00   MOV EAX,DWORD PTR DS:[0x5E2A90]
005717C0  |.  8338 01       CMP DWORD PTR DS:[EAX],0x1
005717C3  |.  75 1C         JNZ SHORT winchm.005717E1
005717C5  |.  FF75 FC       PUSH [LOCAL.1]
005717C8  |.  68 D4185700   PUSH winchm.005718D4                     ;  UNICODE "\r\n"
005717CD  |.  68 E8185700   PUSH winchm.005718E8                     ;  UNICODE "Version: WinCHM Pro"
005717D2  |.  8D45 FC       LEA EAX,[LOCAL.1]
005717D5  |.  BA 03000000   MOV EDX,0x3
005717DA  |.  E8 7D5BE9FF   CALL winchm.0040735C
005717DF  |.  EB 29         JMP SHORT winchm.0057180A
005717E1  |>  FF75 FC       PUSH [LOCAL.1]
005717E4  |.  68 D4185700   PUSH winchm.005718D4                     ;  UNICODE "\r\n"
005717E9  |.  68 1C195700   PUSH winchm.0057191C                     ;  UNICODE "Version: WinCHM (Standard)"
005717EE  |.  8D45 FC       LEA EAX,[LOCAL.1]
005717F1  |.  BA 03000000   MOV EDX,0x3
005717F6  |.  E8 615BE9FF   CALL winchm.0040735C
005717FB  |.  EB 0D         JMP SHORT winchm.0057180A
005717FD  |>  8D45 FC       LEA EAX,[LOCAL.1]
00571800  |.  BA 60195700   MOV EDX,winchm.00571960                  ;  UNICODE "Illegal registration code!"
00571805  |.  E8 0656E9FF   CALL winchm.00406E10
0057180A  |>  8B45 FC       MOV EAX,[LOCAL.1]
0057180D  |.  E8 3650F5FF   CALL winchm.004C6848
这里的关键就是全局地址0x5E260C。
查找对这个全局变量的引用。

这些判读过程分布于程序的整个生命。
程序在启动时读取主表表中保存的RegName和RegCode。根据读取到的信息调用调用sub_005704EC 验证,如果验证不通过就根据第一次使用时间和最后关闭IE的时间的比较判断软件的使用时间。
关键算法:
代码:
[Asm] 纯文本查看 复制代码
005704EC  /$  55            PUSH EBP
005704ED  |.  8BEC          MOV EBP,ESP
005704EF  |.  83C4 D8       ADD ESP,-0x28
005704F2  |.  53            PUSH EBX
005704F3  |.  33C9          XOR ECX,ECX
005704F5  |.  894D F4       MOV [LOCAL.3],ECX
005704F8  |.  894D F0       MOV [LOCAL.4],ECX
005704FB  |.  894D EC       MOV [LOCAL.5],ECX
005704FE  |.  894D E8       MOV [LOCAL.6],ECX
00570501  |.  894D E4       MOV [LOCAL.7],ECX
00570504  |.  8955 F8       MOV [LOCAL.2],EDX                        ;  EDX=00D1E5AC, (UNICODE "1234-5555-6666-7777")
00570507  |.  8945 FC       MOV [LOCAL.1],EAX                        ;  EAX=00D4C7AC, (UNICODE "lacouocu")
0057050A  |.  8B45 FC       MOV EAX,[LOCAL.1]
0057050D  |.  E8 9268E9FF   CALL winchm.00406DA4
00570512  |.  8B45 F8       MOV EAX,[LOCAL.2]
00570515  |.  E8 8A68E9FF   CALL winchm.00406DA4                     ;  结构体
0057051A  |.  33C0          XOR EAX,EAX
0057051C  |.  55            PUSH EBP
0057051D  |.  68 B80D5700   PUSH winchm.00570DB8
00570522  |.  64:FF30       PUSH DWORD PTR FS:[EAX]
00570525  |.  64:8920       MOV DWORD PTR FS:[EAX],ESP
00570528  |.  8D45 F4       LEA EAX,[LOCAL.3]
0057052B  |.  8B55 F8       MOV EDX,[LOCAL.2]
0057052E  |.  E8 DD68E9FF   CALL winchm.00406E10                     ;  copy 2_>>3
00570533  |.  8B45 F4       MOV EAX,[LOCAL.3]
00570536  |.  85C0          TEST EAX,EAX
00570538  |.  74 16         JE SHORT winchm.00570550
0057053A  |.  8BD0          MOV EDX,EAX
0057053C  |.  83EA 0A       SUB EDX,0xA
0057053F  |.  66:833A 02    CMP WORD PTR DS:[EDX],0x2
00570543  |.  74 0B         JE SHORT winchm.00570550
00570545  |.  8D45 F4       LEA EAX,[LOCAL.3]
00570548  |.  8B55 F4       MOV EDX,[LOCAL.3]
0057054B  |.  E8 3C5EE9FF   CALL winchm.0040638C
00570550  |>  85C0          TEST EAX,EAX
00570552  |.  74 05         JE SHORT winchm.00570559
00570554  |.  83E8 04       SUB EAX,0x4
00570557  |.  8B00          MOV EAX,DWORD PTR DS:[EAX]               ;  注册码长度
00570559  |>  8BD8          MOV EBX,EAX
0057055B  |.  A1 902A5E00   MOV EAX,DWORD PTR DS:[0x5E2A90]
00570560  |.  C700 FFFFFFFF MOV DWORD PTR DS:[EAX],-0x1
00570566  |.  8B45 F4       MOV EAX,[LOCAL.3]
00570569  |.  E8 12F6FFFF   CALL winchm.0056FB80
0057056E  |.  8945 D8       MOV [LOCAL.10],EAX                       ;  两个运算结果
00570571  |.  8955 DC       MOV [LOCAL.9],EDX
00570574 >|.  837D DC 00    CMP [LOCAL.9],0x0                        ;  关键算法
00570578  |.  75 13         JNZ SHORT winchm.0057058D
0057057A  |.  817D D8 2E240>CMP [LOCAL.10],0x242E
00570581  |.  75 0A         JNZ SHORT winchm.0057058D
00570583  |.  BB 01000000   MOV EBX,0x1
00570588  |.  E9 10080000   JMP winchm.00570D9D
0057058D  |>  837D DC 00    CMP [LOCAL.9],0x0
00570591  |.  75 13         JNZ SHORT winchm.005705A6
00570593  |.  817D D8 58370>CMP [LOCAL.10],0x3758
0057059A  |.  75 0A         JNZ SHORT winchm.005705A6
0057059C  |.  BB 02000000   MOV EBX,0x2
005705A1  |.  E9 F7070000   JMP winchm.00570D9D
005705A6  |>  837D DC 00    CMP [LOCAL.9],0x0
005705AA  |.  75 13         JNZ SHORT winchm.005705BF
005705AC  |.  817D D8 1A330>CMP [LOCAL.10],0x331A
005705B3  |.  75 0A         JNZ SHORT winchm.005705BF
005705B5  |.  BB 03000000   MOV EBX,0x3
验证注册码的算法:
代码:
[Asm] 纯文本查看 复制代码
0056FBEA  |.  B9 01000000   MOV ECX,0x1
0056FBEF  |>  8B45 F8       /MOV EAX,[LOCAL.2]
0056FBF2  |.  0FB74448 FE   |MOVZX EAX,WORD PTR DS:[EAX+ECX*2-0x2]   ;  szBuf[i]
0056FBF7  |.  F7E9          |IMUL ECX                                ;  i*szBuf[i]
0056FBF9  |.  99            |CDQ
0056FBFA  |.  0345 E8       |ADD EAX,[LOCAL.6]                       ;  local_6+=i*szBuf[i]
0056FBFD  |.  1355 EC       |ADC EDX,[LOCAL.5]
0056FC00  |.  8945 E8       |MOV [LOCAL.6],EAX
0056FC03  |.  8955 EC       |MOV [LOCAL.5],EDX
0056FC06  |.  41            |INC ECX
0056FC07  |.  4B            |DEC EBX
0056FC08  |.^ 75 E5         \JNZ SHORT winchm.0056FBEF
就相当与:
代码:
   
[C] 纯文本查看 复制代码
   char* szBuf="111122223333";//注册码
    int nSum=0;
    for (int i=0;i<strlen(szBuf);i++)
    {
        nSum+=i*szBuf[i];
    }

当然程序中是UNICODE版的。。。。
最后就是用计算出来的nSum跟不同的值比较来区别不同的版本。

Local.10里边就是nsum的结果。

这个算法反推太费事,直接爆破:

00570569  |.  E8 12F6FFFF   CALL winchm.0056FB80

这个事算法call.把开头改为:
Mov eax,0x2c4c
Xor edxx,edx
Retn
就搞定了。

破解感悟】
OD的字符串搜索各种不给力啊!!
机器上没装DEDE,结果走了不少弯路,如果用DEDE找到注册事件,应该就会快很多!!!  

免费评分

参与人数 1热心值 +1 收起 理由
post927 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

Ssking 发表于 2015-4-6 03:08
楼主看雪的? 看雪有这个帖子很久了
 楼主| lacoucou 发表于 2015-4-6 14:47
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-11 02:39

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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