本教程只能用于学习研究,不可进行任何商业用途。如有使用,请购买正版,尊重他人劳动成果和知识产权!
一打开软件,就看到各种注册和未注册提示信息,就有一种想征服它的冲动,而且是很彻底的那种。
思路一:生成序列号
如果我能按照它的加密算法生成序列号,就用不改动原程序了。生成机器码比较简单,注册类有一个Validate验证序列号的函数,但没有告诉怎么生成序列号,应该只有作者才有生成序列号的算法和工具。这个验证函数作用是将序列号各种加码和解码:
最后卡在FormBase64String函数上,大家可以去Msdn去了解一下这个函数。我选择放弃这种方法。
思路二:修改关键跳转
和以前一样,去寻找关键跳转,然后修改它,OK!可故事的结局我又没猜中:我原本以为定位到Register函数中,将"IsValid=flag2&&flag"改为"IsValid=!flag2||flag",反复修改后,还是不起使用,最后我还在这里插入了一个MessageBox来查询IsValid的值,结果根本没Show出来。所以应该是if里面就没有执行,算了。
思路三:彻底修改函数
这个程序破解的关键是GlobalControl窗体中的Register(string serialNumber) 函数,它返回的类型为RegisterResult。这个类型定义如下:IsValid表示是否注册,要改为T才行;ValidTo,注册到好久,即什么时间后过期,改个一万年。
下面是修改方法:
定位到Register函数,在Reflexil的IL代码上右键,选择"Replace all with code…"
打开"Compile"对话框,修改
修改代码(要保证语法没有问题哦),点击左下角的"Compile",如果没有语法问题,右边将会生成IL代码,点击OK即可。如下图:
现在,软件一启动就显示已注册到2115年,使用注册窗口,不输入什么,都注册成功。
其他软件的加密方法也是一样的,关键在于GlobalControl窗体中的Register(string serialNumber) 函数……
本教程只能用于学习研究,不可进行任何商业用途。如有使用,请购买正版,尊重他人劳动成果和知识产权!