经过之前那个道德指责风波过后也有一段时间没写博客了,当然不是我心怀内疚才这么久不写,纯粹是程序员的通病。。怎一个懒字了得,本来想写一些长篇大论反讽一下那些道德高人的。想想还是算了,那样估计会引来新一波攻势,没什么实际意义,影响风气,大家看了也不爽,这次写点有实际意义的,说说我是怎么保护我的代码的,个人心得,如有不妥的地方请见谅。
我们都知道.NET的代码容易被反编译出来,站在破解者的角度来看,破解一个软件情况可分为几种:
1.修改注册验证的代码,达到绕过注册的效果;
2.破解出注册核心算法,写出注册机;
3.完全复制代码,做成一个可编译修改的项目;
从危害是上来看,第三种是最严重的,如果你的软件被实力更强的竞争对手复制了,那简直是毁灭性的打击,理论上.NET没有什么软件是不能破解复制的,只要有高手死了心要破你的软件,保护再好也是无意义的,那时只能认命,当然一般高手也不屑于破解一些没意义的东西。我们虽然做不到完全保护代码,但是我们可以增加他们的破解难度,防不了高手,至少我们要防住像我这种普通的程序员,不能随便什么阿猫阿狗都能染指我们的代码,这简直是对程序员智商的侮辱嘛。
一般我们保护软件的几个重要过程:
1.设计机器码;
2.根据机器码生成注册码;
3.验证注册码(本地+远程验证);
4.给程序集加强命名;
5.对程序集进行代码混淆;
当然这么多步骤一次性也说不完,当前我主要就说说怎么隐藏自己的核心程序集,也就是.DLL动态库。我们平时写项目的时候,里面肯定会有各种各样的动态库出现,当我们编译的时候都会有一个*.DLL的动态库出现,DLL里包含了许多元数据,这就很容易被人用反编译软件完全看到里面的代码,所以隐藏程序集就很重要了,思路是:把程序集存入内存中,到该用的时候才会去用它,这样反编译软件就不能轻易的看到我们的代码了,但是一个比较大的项目,把全部程序集存入内存是不现实的,我们只能把几个比较核心的程序集,如注册验证过程,登陆过程,核心算法过程等隐藏,由于你隐藏了一些重要的程序集,一些人就算得到了你的其他代码,想要软件正确运行还是需要很大的工夫的。by Zengg
花了一点时间写了一个隐藏程序集的的小DEMO,如下图:
这个DEMO的主要功能是:
1.从外部打开某个DLL,并列出该DLL里一共有多少个类;
2.列出某个类里有多少个可执行的公开方法;
3.执行某个方法,会显示执行的返回结果,前提是该方法具有返回值;
4.把从外部打开的DLL转换成C#可用的代码,方便大家存入内存;
5.从内存里读取已经存入内存的程序集,并且执行它的某个类的方法;
下面我们看看项目的VS结构:
我们假设AssemblyTest这个类库是存放我们注册验证的地方,AssemblyWPFDemo就是我们的主程序,一般来说,我们如果要用到AssemblyTest类库的功能时,肯定要由主程序先引用该类库,才能使用这个类库的功能,这里面就存在一个问题,只要引用了类库,在本地就会生成该类库对应的DLL,这个就暴露了我们的代码,下面的过程就是解释,如何在不引用的情况下使用该类库的功能。by Zengg
AssemblyTest类库情况:
有两个测试类,和一个WPF窗体。
namespace AssemblyTest { public class AssemblyTest1 { public string AssemblyTest1GetString() { return "这是Assembly1"; } } }