UltraEdit注册机原理简单说明
UltraEdit注册机原理
By:大志若愚
UltraEdit 是 Windows 下一款流行的老牌文本/HEX 编辑器(非开源)。UltraEdit 正被移植到 Linux 平台。该移植名为 UEX,意即 UltraEdit for Linux。UEX具有原生的 Linux 外观,其界面、配置、热键等与 Windows 版并无二致。对其破解以注册机为最,本文简单的解释了下破解原理。
本文仅仅只是对UltraEdit注册机的反编译,了解UltraEdit注册机的原理。
闲着无事反编译了——UltraEdit注册机,了解了其中的原理。以简单的WinForm程序展示给大家,最主要的无非是对用户码1、用户码2的加密,也可以说是解密[无非对谁来说罢了]。
界面如下:
编辑环境:Microsoft Visual Studio 2010
C#源码百度网盘下载地址:http://pan.baidu.com/s/1ehpKU
核心代码展示:
1 // num1为用户码一,num2为用户码二,返回的为验证码一,验证码二不变。 2 public long GetKey(long num1, long num2) 3 4 { 5 return (((((((((num1 >> 0x13) & 15) * 0x57a8) + (((num1 >> 8) & 0x1f) * 0x50af)) + (((num1 >> 13) & 0x3f) * 0x1694)) + (((num1 >> 0x17) & 0xff) * 0x300)) + ((num1 & 0xff) * 3)) + (num2 * 2)) + 0xb200c0); 6 }
呵呵,来拆分下:
( ( ( ( ( ( (((num1 >> 0x13) & 15) * 0x57a8) + (((num1 >> 8) & 0x1f) * 0x50af) ) + (((num1 >> 13) & 0x3f) * 0x1694) ) + (((num1 >> 0x17) & 0xff) * 0x300) ) + ((num1 & 0xff) * 3) ) + (num2 * 2) ) + 0xb200c0 )
呵呵,来分析下:
最好的方法就是让num1=num2=0,直接得出返回值:0xb200c0即十进制数:11665600
当num1与num1足够小(取0x13,8,13,0x17中的最小值:8)的时候,小于等于8位[2^9-1]的时候就可以看做没有移位操作了,因为此时的移位操作会使该小项为0。
其中:
计算器只能识别和处理2进制数,所以计算机对2进制的处理速度最快,但是相同位数,二进制表示范围最小,但是8进制,16进制转为2进制的速度远远高于10进制数(虽然这个时间差我们感觉不出来,但确实很大),所以一般处理采取16进制数了。
数的含义:
我把:16进制数转为了10进制数,其实计算器对2进制数的识别比较高,速度最快,
16进制数转为2进制数速度也很快,16位数的一位对应2进制数的4位。
比如:0x6=0110[2进制]
0x:开头表示16进制数,0开头则表示8进制数,没有特殊说明一般就是10进制数了。
0x13=19
0x57a8=22440
0x1f=31
0x50af=20655
0x3f=63
0x1694=5780
0x17=23
0xff=255
0x300=768
0xb200c0=11665600
运算符的含义:
>> :右移运算符
位运算,操作对象为位即(0/1)
该运算符为双目运算符,
结合方向:从左到右
作用:
把一个整型数的所有位向右移动指定的位数,移动到右边界之外的多余二进制位会被丢弃,并从左边界移入0。
右移运算的两个操作数应为整数类型:
第一个操作数是要进行移位操作的数
第二个操作数指定第一个操作数移动的位数。
如果第二个操作数等于0则不发生任何移位。
应用举例:
问:计算表达式14 >> 2的值。
答:表达式14 >> 2的值为3,因为14(即二进制的00001110)向右移两位等于3(即二进制的00000011)。
& :按位与
位运算,操作对象为位即(0/1)
该运算符为双目运算符,
规则:
1&1=1; 1&0=0; 0&1=0; 0&0=0
这里就是进行移位和与操作,其中“位”操作改变大小,而“与”操作则改变其逻辑---ture & true = 1,这样实现的加密比较不容易破解,但是还是有某位“大神”破解了,本人只是偷看了他的代码,在这里感谢下他。
呵呵,有点眉目了吧,观摩下。以后可以自己写写属于自己的加密算法。
如果不想让自己的代码被别人看到,就需要加下“壳”了。