【新手】佟爱国老师关於陶永吉RGSSAD游戏的打开等种种问题

40434人阅读
资源分析(20)
游戏是一种神奇的程序,很多爱好者使用RpgMaker制作自己的游戏。虽然我对于游戏制作的经历不是从RpgMaker开始,但是是RpgMaker让我知道了一个RPG应有的组成元素;虽然我早已不用RpgMaker做任何东西,但是我还希望能为RpgMaker做点什么。
有些人用着盗版的Windows,网上下载的RpgMaker,商业游戏的素材,别处抄来的RGSS脚本,复刻的老游戏的剧情,最后发布的时候却加了密,的确是不厚道的做法。
本文将简单介绍RGSSAD文件的解密方法,以及更好的加密方案。
作者:leexuany(小宝)
郑重声明:本文仅供学习交流使用,不得用于商业用途。强烈鄙视伸手党和剽窃他人作品的行为。如果你为剽窃他人的脚本、素材甚至整个游戏而来,本作者谢绝你使用本文提供的任何技术和解密程序。
零、你是否应该继续阅读?
如果你愿意遵守"郑重声明"中的要求,那么你可以继续。如果你认为解密是一个禁忌的话题,那么你可以离开了。如果你认为解密工具在严重侵害你的利益,那么你应该认真地阅读全文。如果你想讨论,那么回帖是你最好的选择。如果你想更好的保护你的游戏,那么就不要公开谈论你的方法。如果你想开始阅读,那么就继续吧。
一、RGSSAD Extractor
RGSSAD Extractor的工作原理是让游戏自己解密RGSSAD文件,当游戏把资源读入内存之后,在通过脚本抓取内存。因此RGSSAD Extractor 存在两个缺点:1、它提取的并不是RGSSAD包内的原始素材。你可以在游戏里添加一张jpg格式的图片,如果不出意外RGSSAD Extractor 解出来的肯定是png格式的。虽然画面是一样的,但是对于我这样的素材完美主义者,这是决不允许的。2、它的提取速度实在是太慢了,等待的时间足以使人疯掉。
因此我们需要知道RGSSAD的格式,然后写自己的解包工具。
二、RGSSAD资源格式
开始的8字节是文件标志,用于判断是不是RGSSAD文件。然后是n个struct SubFile{&&& unsign&&& filenamesize 字节的文件名;&&& un&&& filesize 字节的文件正文;};不过所有的SubFile结构都是xor加密过的。MagicKey的初值是0xDEADCAFEMagicKey 的变换规则为 MagicKey = MagicKey * 7 + 3;其中文件名是按字节异或,filenamesize filesize 以及文件正文都是按双字异或的。
如果你还有什么细节不清楚,可以直接查阅我上传的源代码。
三、小宝的解包工具
对于不会编程的朋友,可以直接下载我编译好的版本。(使用者请严格遵守我前面的声明)
四、防范措施与加密方案
方案一:使用自己的加密/解密算法
第一种加密方案是修改RGSS102J.dll中的解密算法,然后自己把素材打包成RGSSAD格式。
此方案要求使用者对程序设计以及二进制文件的修改有一定的基础。
由于小宝现在还没有试过外挂dll这种技术,所以这里介绍一个相对简单的方法----修改MagicKey的初始值。在前面一节中,我们知道RMXP是使用0xDEADCAFE作为MagicKey的初始值,那么我们把RGSS102J.dll中的DEADCAFE修改掉,然后自己打包就可以防范那些一般的解包工具(比如我提供的那个,还有RGSSAD Extractor)。
当然,如果你觉得有必要的话,还可以给这个修改过的dll文件加一个强壳,然后随游戏发布。
方案二:混淆文件名
第二种加密思路是混淆文件名。在Windows操作系统下,有 //:*?"&&| 这9个字符是不能用作文件名的。除去//表示文件目录,我们还有7个特殊字符可用。如果在原有文件名中加入这几个本来不能用的字符,那么解包程序就会因为不能正常创建文件而提取失败。
注:此方法需要自己打包资源文件,以及修改rxdata文件,工作量比较大。
混淆不能绝对保证自己的游戏不被盗用,它的主要目的是打击盗用者的信心,让他在还没有导出全部素材的时候就已经垂头丧气,精疲力尽了。
当然对于游戏而言,无论什么样的加密方案都只是增加破解者的工作强度,而不能真正保护自己的素材不被提取,因为素材终归是要在游戏中使用的。
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:237045次
积分:2770
积分:2770
排名:第10684名
原创:48篇
评论:192条
(1)(2)(1)(2)(2)(2)(3)(1)(1)(1)(1)(1)(1)(2)(3)(4)(1)(3)(3)(5)(1)(10)(1)

参考资料

 

随机推荐