c# dll 加密最快的方法使用加壳工具Virbox Protector,直接加密,Virbox Protectorke可以对dll进行性能分析,分析每个函数的调用次数,对每个函数选择保护方式如:混淆/虚拟化/碎片化/代码加密等;每种加密方法的特点是什么呢?
代码加密(X86):
针对X86汇编代码:一种代码自修改技术(SMC)保护代码。把当前代码加密存储为密文,存储起来,当程序运行到被保护函数时候自动解密并且执行,执行之后再擦除代码,运行到哪里才解密哪里的代码,黑客无法获得原始机器指令和内存完整性的代码,由于是纯内存 *** 作所以运行速度快, 性价高的保护手段,建议全加
代码加密(IL)
针对dotNet程序,保护IL代码:一种动态运行方法解密被保护代码。把当前代码加密存储为密文,存储起来,当程序运行到被保护函数时候自动解密并且执行,执行之后再擦除代码,执行之后再擦除代码,运行到哪里才解密哪里的代码,黑客无法获得原始的中间语言的指令和内存完整性的代码,由于是纯内存 *** 作所以运行速度快, 性价高的保护手段,建议全加
压缩
类似zip等压缩软件把代码和数据段压缩,由于带有动态密码,没有任何工具可以自动脱壳,是防止反编译和反汇编关键手段。
代码混淆(IL):
将代码中的各种元素,如变量,函数,类的名字改写成无意义的名字。比如改写成单个字母,或是简短的无意义字母组合,甚至改写成“__”这样的符号,使得阅读的人无法根据名字猜测其用途。
a)重写代码中的部分逻辑,将其变成功能上等价,但是更难理解的形式。比如将for循环改写成while循环,将循环改写成递归,精简中间变量,等等。
b) 打乱代码的格式。比如删除空格,将多行代码挤到一行中,或者将一行代码断成多行等等。
c) 添加花指令,通过特殊构造的指令来使得反汇编器出错,进而干扰反编译工作的进行。
代码混淆器也会带来一些问题。主要的问题包括:· 被混淆的代码难于理解,因此调试除错也变得困难起来。开发人员通常需要保留原始的未混淆的代码用于调试。· 对于支持反射的语言,代码混淆有可能与反射发生冲突。· 代码混淆并不能真正阻止反向工程,只能增大其难度。因此,对于对安全性要求很高的场合,仅仅使用代码混淆并不能保证源代码的安全。
代码混淆的特点是安全度低、不会影响效率。
代码虚拟化:
针对X86代码: 是指将机器代码翻译为机器和人都无法识别的一串伪代码字节流;在具体执行时再对这些伪代码进行一一翻译解释,逐步还原为原始代码并执行。 这段用于翻译伪代码并负责具体执行的子程序就叫作虚拟机VM(好似一个抽象的CPU)。它以一个函数的形式存在,函数的参数就是字节码的内存地址。 由于虚拟机代码和虚拟机CPU的实现可以做到每次都是随机设计和随机执行 并且代码每次可以随机变化,包括一些逻辑上的等价变化可以参考硬件N个与非门NOT-AND实现各种逻辑门,算法和访问内存形式的变化,包括数学上的非等价变化,代码体积几乎可以膨胀达到100到10000倍,造成机器无法做算法还原到原有逻辑。
代码虚拟化的特点是:安全度中、不会影响效率。
代码碎片化:
深思自主知识产权的最新技术:基于 LLVM 和 ARM 虚拟机技术,自动抽取海量代码移入 SS 内核态模块,极大的降低了使用门槛, 不再需要手动移植算法,可移植的算法从有限的几个增长到几乎无限多,支持的语言也不再限于 C, 这是加密技术的一次综合应用,效果上类似于将软件打散执行,让破解者无从下手。
安全度高、建议关键函数或调用加密锁方法;使用太多会影响效率
打乱Ascii字符串,让OD无法辨别出明文字符串防止被OD跟踪
关键数据代码用RAS或DES等加密算法加密,等用到时在解密
CRC32或MD5取校验数据值,数据被改动这CRC32和MD5也会变动
变量验证或循环冗余验证,发现破解不要立即结束程序,让他跟一段在结束(例如:延时)
检查程序函数是否被HOOK(防止利用关键函数破解),模块是否正常(防止程序被劫持)
利用内存CRC校验程序代码段,发现代码被修改立刻结束或标记。
使用高强度加密壳来VM关键代码,比如:SE、VMP、VP、TMD、Enigma等等
易语言防破解方法多不胜数,关键还是思路和技术,思路到了没技术也是写不出代码的!
三百分。。诱惑很大啊。。
上面那个干脆就复制了一段文章来,啰嗦不说,还不全。。
(起码要把别人文章的分段代码去掉啊。。)
简单和你说吧,别人破解你的程序就是通过“脱壳”,跳过你的那段验证代码,是你的程序无法正常实行判断,就没办法验证是否是正版用户。而此时,我们就要想办法使他们没办法跳过我们写的判断语句。
可以从这几个方面来想。
我们可以用花指令打乱代码,使他们找不到判断验证的指令。这样说可能太复杂了,形象点说吧。
就是原来判断语句可能是有两种结果,这样他们就能轻松找到我们的判断语句,然后从容跳过。我们用花指令的话,就可以把两个变成四个,甚至更多。这样破解者就找不到你的判断语句了。
也不说多了,小程序的话,你直接去网上找几个免费加壳软件加个壳,一般就OK了。
要是商业软件的话,建议购买专业的加壳程序。
这种专业收费的一般设计比较严谨,一般的破解者是弄不开的。
希望有帮助。
1、代码中减少明文字符串的出现,可以进行加密,包括常量等,减少运行后内存中可能存在的文本信息。
2、启动一个线程对程序中的一些关键信息进行时钟性的检测,若出现被修改就退出。
3、利用外部的web等,储存程序中关键信息,比如程序的exe的MD5码,程序运行后首先去网络获取本版本的MD5,若不一致,则被修改过。
4、有反OD模块等,防破解模块。比如用了反OD模块,在装有OD破解软件的电脑上运行 时,可以终止运行。
5、少使用如果、如果真这种流程语句。而是使用“判断()”判断上可以多加无效的判断分支,这样加大切入点破解难度。
6、等等
以上就是关于c#怎么加密 防止被破解全部的内容,包括:c#怎么加密 防止被破解、易语言怎么防破解、易语言如何防止破解等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)