《万能数据库查询分析器》的EXE文件加壳技术

《万能数据库查询分析器》的EXE文件加壳技术

<wbr><wbr><wbr><wbr><wbr> 马根峰<wbr> ( 广东联合电子收费股份有限公司, 广州 510300)</wbr></wbr></wbr></wbr></wbr></wbr>

<wbr></wbr>

<wbr></wbr>

作者博客:

新浪博客: <wbr><wbr><a href="http://blog.sina.com.cn/magenfeng">http://blog.sina.com.cn/magenfeng</a></wbr></wbr>

搜狐博客: <wbr><wbr><a href="http://magenfeng.blog.sohu.com/">http://magenfeng.blog.sohu.com/</a><wbr></wbr></wbr></wbr>

QQ空间: <wbr><wbr><wbr><a href="http://630414817.qzone.qq.com/">http://630414817.qzone.qq.com/</a><wbr></wbr></wbr></wbr></wbr>

CSDN文库: http://download.csdn.net/user/magenfeng

CSDN博客: http://blog.csdn.net/magenfeng

<wbr></wbr>

<wbr><wbr></wbr></wbr>

1<wbr><wbr><wbr><wbr><wbr><wbr> 引言 <wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><span style="font-size:13px"><wbr>对于一个程序开发单位或者个人而言,如何才能防止别人使用DEBUG工具来破解您的程序,更好地保护您的知识产权?</wbr></span></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr><span style="color:#ff0000"> 一个比较通用的做法就是把你的EXE文件进行加壳</span></wbr></wbr></wbr></wbr>,即将EXE文件进行切分、加密。对外您只需发布各个加密的EXE子文件,而不用提供EXE文件。这样别人也就无法DEBUG您的EXE文件来进行破解。

<wbr><wbr><wbr><wbr><span style="color:#ff0000">在系统启动时,通过运行EXE外壳程序,来对各个加密EXE子文件进行解密并加载到一块内存中,从而在内存中直接启动您的应用程序。</span></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr> 总之,在发布软件时,您可以不发布EXE文件,只发布各个加密的EXE子文件和EXE外壳引导程序,实现对您的软件的保护。</wbr></wbr></wbr></wbr>

<wbr></wbr>

<wbr></wbr>

2<wbr><wbr><wbr><wbr><wbr> 万能数据库查询分析器所采用的软件保护技术</wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><span style="font-size:13px"><wbr><wbr> 中国本土程序员马根峰推出的个人作品----万能数据库查询分析器,其中文版本《DB 查询分析器》、英文版本《DB Query Analyzer》。它集哈希技术、链表</wbr></wbr></span><span style="font-size:13px">等多种数据结构于一体,使用先进系统开发技术,经历4年的研究、开发、测试周期,长达5万多行代码的工作量,使得万能数据库查询分析器具有强大的功能、友</span><span style="font-size:13px">好的操作界面、良好的操作性、跨越数据库平台。</span></wbr></wbr>

<wbr><wbr><wbr><wbr> 出于对对自已程序的保护,马根峰同样对中英文版本的EXE程序文件进行了加壳技术。<span style="color:#ff0000"><strong>从系统产生至今的三个版本,1.0版本、1.03版本到1.04版本都采用</strong></span></wbr></wbr></wbr></wbr>了加壳技术,并且EXE文件进行切分、加密是用自己开发的程序所完成。发布的安装程序中“DB_part1.del”、“DB_part2.del”、“DB_part3.del”、“DB_part4.del”就是万能查询分析器中英文版本的EXE文件所切分、加密后的密文文件,具体的生成过程见图1所示。

<wbr><a href="http://photo.blog.sina.com.cn/showpic.html#blogid=4b70463f0100vx1r&amp;url=http://s6.sinaimg.cn/orignal/4b70463fgb2b70b8a7935" target="_blank"></a><br><img alt="" src="http://hi.csdn.net/attachment/201201/6/0_13258337244brv.gif"><br><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>图1<wbr><wbr> 《万能数据库查询分析器》EXE文件的切分、加密过程</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr></wbr>

<wbr></wbr>

<wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><span style="font-size:13px"> 用户下载《万能数据库查询分析器》中英文版本安装程序,在计算机上安装后,就可以运行了。整个程序运行的过程如图2所示。</span></wbr></wbr></wbr></wbr></wbr>

<wbr><a href="http://photo.blog.sina.com.cn/showpic.html#blogid=4b70463f0100vx1r&amp;url=http://s2.sinaimg.cn/orignal/4b70463fgb2ca50849481" target="_blank"></a><br><br><a href="http://photo.blog.sina.com.cn/showpic.html#blogid=4b70463f0100vx1r&amp;url=http://s14.sinaimg.cn/orignal/4b70463fgb2b70c7ea6dd" target="_blank"></a><img alt="" src="http://hi.csdn.net/attachment/201201/6/0_1325833744aaUa.gif"><br><br><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> 图2<wbr><wbr> 《万能数据库查询分析器》的装载与执行过程</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr></wbr>

<wbr><wbr><wbr><wbr><wbr><span style="font-size:13px">“<strong><span style="color:#f815ff">DBQueryAnalyzer.ex_</span></strong>”(这是安装前的文件名,安装到计算机系统中之后,名称就变成“<span style="color:#f815ff"><strong>DBQueryAnalyzer.exe</strong></span>”),<strong><span style="color:#f815ff">就是自己所编写的</span><span style="color:#f815ff">EXE</span><span style="color:#f815ff">外壳引</span></strong></span><span style="font-size:13px"><strong><span style="color:#f815ff">导程序</span></strong>。“DBQueryAnalyzer.ex_”的作用就是将EXE文件切分、加密后的四个子文件“DB_part1.del”、“DB_part2.del”、“DB_part3.del”、</span><span style="font-size:13px">“DB_part4.del”解密,然后组装后装入内存,这时EXE外壳引导程序“DBQueryAnalyzer.exe”就退出运行,调用内存中“万能数据库查询分析器”的执行文件</span><span style="font-size:13px">区域。</span></wbr></wbr></wbr></wbr></wbr>

<wbr></wbr>

<wbr></wbr>

<wbr></wbr>

3<wbr><wbr><wbr><wbr><wbr><wbr><wbr> 计算机病毒的重要特征</wbr></wbr></wbr></wbr></wbr></wbr></wbr>

计算机病毒具有以下几个特点:

寄生性

  <wbr><wbr><wbr><wbr> 计算机病毒寄生在其他程序之中,当执行这个程序时,病毒就起破坏作用,而在未启动这个程序之前,它是不易被人发觉的。</wbr></wbr></wbr></wbr>

传染性

  <wbr><wbr><wbr><wbr> 计算机病毒不但本身具有破坏性,更有害的是具有传染性,一旦病毒被复制或产生变种,其速度之快令人难以预防。<strong>传染性是病毒的基本特征</strong>。</wbr></wbr></wbr></wbr>

潜伏性

  <wbr><wbr><wbr><wbr> 有些病毒像定时一样,让它什么时间发作是预先设计好的。比如黑色星期五病毒,不到预定时间一点都觉察不出来,等到条件具备的时候一下子就爆炸开来,对系统进行破坏。</wbr></wbr></wbr></wbr>

破坏性

  <wbr><wbr><wbr><wbr><strong>计算机中毒后,可能会导致正常的程序无法运行,把计算机内的文件删除或受到不同程度的损坏</strong> 。通常表现为:增、删、改、移。</wbr></wbr></wbr></wbr>

可触发性

  <wbr><wbr><wbr><wbr> 病毒因某个事件或数值的出现,诱使病毒实施感染或进行攻击的特性称为可触发性。为了隐蔽自己,病毒必须潜伏,少做动作。如果完全不动,一直潜伏</wbr></wbr></wbr></wbr>的话,病毒既不能感染也不能进行破坏,便失去了杀伤力。病毒既要隐蔽又要维持杀伤力,它必须具有可触发性。

<wbr></wbr>

4<wbr><wbr><wbr><wbr><wbr><wbr><wbr> 加壳技术的美中不足</wbr></wbr></wbr></wbr></wbr></wbr></wbr>

EXE文件加壳技术有效的保护了自己的软件,然而由于其加载到内存运行的原理有点类似于病毒的工作原理,所以被相当一部分杀毒软件误认为是木马病毒。但在一个程序中往往会调用另外的程序、或者动态分配内存,仅凭这一点就作为判断病毒的依据,岂非有点儿戏。

从另一方面讲,《万能数据库查询分析器》根本不具有计算机病毒的特征:寄生性、传染性、潜伏性、破坏性、可触发性。所以我都不知道国内外的杀毒软件产品依据什么来将《万能数据库查询分析器》误判为计算机病毒,真是颇为费解。

尽管本人已经发信给国内外的杀毒软件商,告知他们本人的程序,但由于别人财大气粗,效率不高,至今《万能数据库查询分析器》的中文版本《DB 查询分析器》、英文版本《DB Query Analyzer》的安装程序依然被当成木马病毒而误杀。

很不可思议的是,2007年5月份在国内外各大软件下载网站(包括国外的download.com、softpedia.com,并且后者还声明说“DB Query Analyzer -SOFTPEDIA "100% CLEAN" AWARD”)发布时都没有被误杀啊,怎么今年就开始误杀了呢,木马病毒都出现了多少年了噢,真是想不通啊!

<wbr></wbr>

<wbr></wbr>

技术交流的话,

联系方式:

QQ:630414817

MSN: [email protected]

QQ添加好友时请输入验证信息:查询分析器



《万能数据库查询分析器》的EXE文件加壳技术

你可能感兴趣的:(数据库)