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

推荐文章

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

ShowDep 4.0 beta 1

 作者:本站收集   日期:2005-5-27
字号选择〖 〗/ 双击滚屏 单击停止   
这个东西判断注册码用的是两个迭代,这两个迭代用的是同样的计算
公式,且前一个迭代的输出作为后一个迭代的输入。第一个是对
Name进行迭代,第二个则是对Serial进行迭代。迭代过程中要查一
个表。假定你输入的注册码是“11223344”,则Serial[ ]={0x44,
0x33,0x22,0x11}。

迭代是针对3个长整数(a,b,c)来进行的,用a[k]、b[k]、c[k]分别表示第k轮迭代之前这3个长整数的值,
用a[k+1]、b[k+1]、c[k+1]分别表示第k轮迭代之后这3个长整数的值,
用Name[k]和Serial[k]分别表示你输入的名字和注册码的第k个字节的值,则有迭代公式:
1、a[k+1] = (a[k] >> 8) ^ Table[4 * ((a[k] & 0xFF) ^ Name[k])];
2、b[k+1] = ((a[k+1] & 0xFF) + b[k]) * 0x08088405 + 1;
3、c[k+1] = (c[k] >> 8) ^ Table[4 * ((c[k] & 0xFF) ^ (b[k+1] >> 24))];
迭代的初始条件为a[0]=0x12345678,b[0]=0x23456789,c[0]=0x34567890。

以上是针对Name进行迭代,之后还要对Serial进行迭代,将上面的Name[k]用Serial[k]代替即可。
对Name进行迭代后得到的三个长整数将作为对Serial进行迭代的初始值。

注册码正确的条件为:最终得到的第3个长整数为0,即c = 0。

谁能将这个算法求逆? 这个也许是密码学里头的某种算法,不知谁懂这个?
上一篇:注册算法分析    下一篇:RCCD and RCCDPlus 算法分析  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-5-27
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿