庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>安全技术>软件破解>算法研究>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

S-Spline 算法分析

 作者:本站收集   日期:2005-5-27
字号选择〖 〗/ 双击滚屏 单击停止   
这个玩意儿在启动的时候进行判断,如下:

015F:00401E4E  CALL      0045A590          //从注册表中读出注册码
015F:00401E53  MOV      [004C4D10],EAX    //保存在全局变量中
015F:00401E58  DEC      DWORD PTR [EBP-44]
015F:00401E5B  LEA      EAX,[EBP-14]
015F:00401E5E  MOV      EDX,00000002
015F:00401E63  CALL      004BF1C0
015F:00401E68  MOV      ECX,[004C4D10]    //取出注册码
015F:00401E6E  XOR      ECX,1385A3F6      //与常数异或
015F:00401E74  TEST      ECX,FFF00000      //再与常数相与
015F:00401E7A  JNZ      00401EBD          //jump if bad guy

由上可知,注册码code应满足如下条件:
        (code ^ 0x1385A3F6) ^ 0xFFF00000 = 0
亦即
        code ^ 0x1385A3F6 = 0x000yyyyy
其中y可以是任意十六进制数字。故注册码的十六进制形式的高3位为138。

用BPM 004C4D10设断点,到了如下的地方:

015F:00404018  MOV      ECX,[004C4D10]    //取出注册码
015F:0040401E  XOR      EDX,EDX
015F:00404020  MOV      EAX,ECX
015F:00404022  AND      ECX,000FFFFF      //与掩码相与,取出低20个bit
015F:00404028  AND      EAX,FFF00000      //与掩码相与,取出高12个bit
015F:0040402D  SHR      EAX,14            //将高12个bit移到最右边
015F:00404030  SHL      ECX,0C            //将低20个bit移到最左边
015F:00404033  OR        EAX,ECX            //至此高12 bit和低20 bit交换了位置
015F:00404035  MOV      ECX,000000C5
015F:0040403A  XOR      EAX,17293843      //换位后再与常数异或
015F:0040403F  DIV      ECX                //对0xC5求余
015F:00404041  TEST      EDX,EDX
015F:00404043  JNZ      0040406F          //余数不为0就错误

根据上面的分析,我们可以写个小程序穷举一下,找到一个合适的注册码327155958。

#include <stdio.h>

void main(void)
{

    unsigned long k;
    unsigned long a;

    for (k = 0x00000; k <= 0xFFFFF; k++)
    {
        a = ((k << 12) | 0x00000138) ^ 0x17293843;

        if ((a % 0xC5) == 0)
        {
            printf("Foud a valid code: %lu\n", k | 0x13800000);
            break;
        }
    }
}

不好意思,这句笔误:(code ^ 0x1385A3F6) ^ 0xFFF00000 = 0 ,应为(code ^ 0x1385A3F6) & 0xFFF00000 = 0 (空)

上一篇:Barcode Magic 算法分析    下一篇:附录A、常用字符的7位ASCII值  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-5-27
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿