防止非授权用户调用DLL
1、首先要创建一个密钥文件(*.snk)
打开VS的命令行工具,输入命令:sn -k f:\PublicKey.snk。按回车键命令行会自动生成一个密钥文件。
f:\ —— 是密钥文件输出的位置,这个可以自己设置,如果不添加,密钥文件则会自动生成在命令提示行的根文件夹下
PublicKey —— 是密钥的文件的文件名,可以自己随意起名字
2、为项目添加密钥文件
3、设置DLL中所有类的修饰符
DLL所有的类,除了单独留下一个修饰符为 public 完全公开的类,作为公共出口,其余的类的修饰符全部更改为 internal 仅程序集可见
4、为程序集唯一的公共类添加校验方法
该程序集中,所有类包含的对外方法,都要通过唯一公共类来进行调用,要注意的是,该公共类中所有的方法和属性等,
不能是静态的。而校验密钥的方法,则放在该公共类的构造函数当中。
公共密钥里的“公共密钥标记”和“公共密钥”可以通过在这个方法里加入断点查看(也可以使用VS命令行来获得),然后
在经过MD5加密后,得到密钥和密钥标记,并设置为常量。
将该程序集生成为DLL,并使用代码混淆软件进行混淆(注意:如果程序集中有涉及到序列化和反序列化,请不要使用代码
混淆软件,因为程序集中有序列化和反序列化的应用,使用代码混淆软件混淆后,有可能使应用到序列化和反序列化的地方
出现异常或不可预知的错误)。
总结、如此设置后,只要调用该DLL的项目没有添加指定的密钥文件,基本上就无法使用该DLL文件中的任何方法。当然凡事
并不绝对,这样做只能是让没有得到授权的用户使用该程序集生成的DLL的使用成本大大提高罢了。任何的加密方法也不能说
是百分之百安全。这是本人的一点愚见,如有遗漏或错误,还请指正。
想找一个无人的角落发呆……