.NET破解之爱奇迪(三)

本教程只能用于学习研究,不可进行任何商业用途。如有使用,请购买正版,尊重他人劳动成果和知识产权!

.NET破解之爱奇迪(一)

.NET破解之爱奇迪(二)

一打开软件,就看到各种注册和未注册提示信息,就有一种想征服它的冲动,而且是很彻底的那种。

思路一:生成序列号

如果我能按照它的加密算法生成序列号,就用不改动原程序了。生成机器码比较简单,注册类有一个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) 函数……

本教程只能用于学习研究,不可进行任何商业用途。如有使用,请购买正版,尊重他人劳动成果和知识产权!

原文地址:https://www.cnblogs.com/liweis/p/4527744.html