欢迎来到天天文库
浏览记录
ID:9618165
大小:49.50 KB
页数:3页
时间:2018-05-04
《谈应用软件的破解与保护》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、谈应用软件的破解与保护谈应用软件的破解与保护 开发软件时,尤其当用到商业用途时,注册码和激活码是非常重要的,未注册的用户会加上某些限制,如使用天数,延迟,未注册画面等等。但是现在的软件破解技术十分强大,各种国内外大型软件都有注册机制,却同时也不断地被破解,国家一再加大力度,打击非法软件出版物,扶持正版软件,但实际效果并不理想。大多的软件商选择了购买加密产品或者加密技术来保护自己的软件,软件保护一般分为软加密和硬加密。 1、常见的软件破解方法 首先我们来了解一下破解中几个重要的专业术语。 (1)
2、断点,所谓断点就是程序被中断的地方,中断就是由于有特殊事件发生,计算机暂停当前的任务,转而去执行另外的任务,然后再返回原先的任务继续执行。解密的过程就是等到程序去获取我们输人的注册码并准备和正确的注册码相比较的时候将它中断下来,然后我们通过分析程序,找到正确的注册码。 (2)领空,所谓程序的领空,就是程序自己的领土地盘,也就是我们要破解的程序自己程序码所处的位置。每个程序的编写都没有固定的模式,所以我们要在想要切人程序的时候中断程序,就必须不依赖具体的程序设置断点,也就是我们设置的断点应该是每个程
3、序都会用到的东西。 (3)API,即ApplicationProgrammingInterface的简写,我们叫应用程序编程接口,是一个系统定义函数的大集合,它提供了访问操作系统特征的方法。API包含了几百个应用程序调用的函数,这些函数执行所有必须的与操作系统相关的操作,如内存分配、向屏幕输出和创建窗口等,.用户输人的信息与软件通过的算法生成的注册码相等,程序就会注册成功,否则就会注册失败。 1.2利用算法注册机。算法注册机是要在分析了软件的注册码算法的基础上,制作出来的一种可以自动生成软件注册
4、码的程序。所以软件的算法很重要,一般软件作者自己也编写,方便软件的销售使用。这类软件加密的特点是一个注册码只能在一台电脑上使用,像和电脑进行了一对一的绑定。使用步骤是首先运行试用的软件,得到本台机器的软件机器码,再用算法注册机算号注册,然后用算法注册机直接算出合适的注册码,最后用算出来的注册码直接注册。 1.3利用内存破解。我们知道所有正在运行的程序的数据,全部都要加载到内存中去,软件在进行注册码认证的时候会有个比较的过程,所以我们只须知道所要破解软件的注册码的内存地址,就达到目的了。这种方法的优
5、点是无须花大力气掌握软件注册码的算法,非常节省编写内存注册机的时间。步骤是先加载内存注册机,再通过它去获得内存中软件的真实注册码,或修改内存中软件相关的某些数据,来达到破解软件的目的。主要有2种方式,第一种直接从内存中得到注册码,第二种在内存中模拟已注册程序的运行环境。 1.4补丁破解法和文件注册法。补丁破解法是指用相关的补丁程序来修改软件,以达到破解软件的目的。此方法一般是破解软件的验证注册码或时间,基本上都是修改原程序的判断语句。 2、常见的软件保护方法 2.1注册码。软件的注册码一般都是
6、一机一个,不能重复。下面我们来看看如何实现的。 第一步根据硬盘卷标和CPU序列号,生成机器码,首先编写publicstaticstringGetDiskVolumeSerialNum-ber()函数取得设备硬盘的卷标号,其次编写publicstaticstringgetCpu()函数获得CPU的序列号,最后生成机器码,函数如下: StringNumber;StringpublicstaticstringgetsoftNum() {strNum-=getCpu+GetDiskVolumeSeri
7、al-strsoftNum=strNum.Substring(0,24);//从生成的字符串中取出前24个字符做为机器码returnstrsoftNum;} 第二步根据机器码生成注册码,需要编写publicstaticstringgetRegistNum()函数来实现。第三步。检查注册状况,若没有注册,可自定义试用天数,延迟,未注册画面等等,可编写privatevoidCheckRegist0Cpl数来实现。2.2软加密。所谓软加密就是不依靠特别硬件来实现的对软件的保护技术。当前国际上比较通用的软
8、件都采取软加密的方式,例如微软的adillo,其特点是双进程互相检测,(5)themida,其特点是采用虚拟机技术。好的加密效果在于让盗版者在破解被保护的软件时,付出巨大的代价,耗费极大的时间精力,最终被迫放弃攻击。 2.3硬加密。硬加密就是我们所说的加密狗或加.L.密锁,是一种插在计算机USB口或并口上的软硬件结合的加密产品,目前绝大部分都是USB口形式,是基于硬件保护技术,其目的是通过对软件与数据的保护防止知识产权被非法使用,是保证高档软件在市场生命周期中免受盗
此文档下载收益归作者所有