文档章节

quick-cocos2d-x 加密

piggybear
 piggybear
发布于 2015/02/16 10:32
字数 1489
阅读 7
收藏 0

阿里云携手百名商业领袖、技术大咖,带您一探行进中的数字新基建!>>>

开发环境:Xcode 5.0 + quick-cocos2d-x-2.2.5


如果开发者不想让游戏中的资源或脚本文件轻易的暴露给其他人,一般会采用对文件进行加密的方式来保护文件或资源被盗用。quick-cocos2d-x 为开发者提供了xxtea加密算法,用来对脚本文件及资源进行加密,加密对象大体分为如下几种:

1.对脚本/资源文件本身加密

2.将脚本/资源文件压缩成zip,对zip进行加密

3.对脚本/资源文件加密后,再将其压缩后的zip再次加密


首先来演示对脚本文件的加密


1.创建一个新工程,名为quicktest。

通过控制台进入到该工程目录下,例:

cd /Users/Helloworld/Desktop/quick-cocos2d-x-2.2.5/bin/quicktest


2.执行 compile_scripts.sh脚本(位于quick-cocos2d-x-2.2.5/bin文件夹下。windows下执行.bat),执行时需要输入若干个参数,这里简单介绍一下各个参数的功能(也可以直接查看对应的php脚本文件或输入-h查看帮助):

    -h 帮助
    -i  源文件目录
    -o 输出文件目录/输出文件名
    -p 包前缀名字
    -x  不包含的包,即当前目录下的哪些包不希望被添加进去
    -m 编译模式,包含两种,一种是默认的打包成zip,另外一种是不打包直接生成一个个的文件
    -e 加密模式,包含两种,xxtea_chunk是对文件本身进行加密,xxtea_zip是对打包后的zip进行加密
    -ek 加密秘钥
    -es 加密签名
    -ex 加密文件的后缀名,默认是lua
    -c 从一个文件加载参数列表
    -q 生成过程不输出信息


例:

/Users/Helloworld/Desktop/quick-cocos2d-x-2.2.5/bin/compile_scripts.sh -i scripts -o res/game.zip -e xxtea_zip -ekMYKEY -es XT


上面这段代码的作用,是将 scripts 文件夹中的脚本文件压缩,并存放到res目录下,压缩后的文件名为game.zip,加密方式采用的是对zip压缩包进行加密,如果采用文本方式加密则-e 后应该写 xxtea_chunks。秘钥和签名将会在代码中使用。操作完整截图如下:


下面打开quick-cocos2d-x/bin/quicktest/res ,可以看到里面有两个压缩包,其中framework_precompiled.zip是引擎自带的,而另外一个则是我们刚刚生成的,双击game.zip之后你会发现解压出来的是一个game.zip.cpgz的文件,然后双击这个.cpgz的文件之后又会生成game.zip文件,原因是这个zip已经被加密,所以无法识别了。如果这里采用的是脚本加密的方式或不加密的方式则可以正常解压。


之后在引擎中使用加密后的脚本文件时,只需将AppDelegate.cpp中原本执行脚本文件的那段代码替换为如下代码:


    pStack->setXXTEAKeyAndSign("MYKEY"5, "XT"2);

    pStack->loadChunksFromZIP("res/game.zip");

    pStack->executeString("require 'main'");


其中第一行代码中的5和2代表的是字符串"MYKEY"和"XT"的字符个数为5和2。



脚本加密的方式大体如上文所述,至于资源加密的方法与脚本加密类似,在进入quicktest目录下之后执行pack_files.sh脚本(win执行pack_files.bat)。输入-h查看帮助


第一个样例,是将res中的资源文件进行加密,加密后的文件存放到resnew文件夹中;第二个是讲res中的资源打包成zip存放到game.zip,并未加密;第三个是存放到zip中后并对zip进行加密。还有另外一种方式就是两种方法结合使用,将资源加密后存放到某一文件夹,之后再重新执行一次脚本将这些加密后的文件打包成zip再加密。


之后还需要在AppDelegate.cpp中加一段代码:

    pStack->setXXTEAKeyAndSign("XXTEA"5,"tsts",4);

如果将资源压缩成了zip包,还需对其进行解压。最后打包时在项目中的资源或脚本仅保留.zip即可,原本的资源及脚本直接删除其引用即可,不要直接把文件丢进垃圾桶。



还有一点需要说明的是,该方法并非只能对quick-x中的资源加密,比如,如果开发者使用的是cocos2d-x 2.2.5的版本,但是却希望使用quick-x中的加密方法对资源及脚本进行加密,这样也是可以的。加密的步骤与上述相同,但由于cocos2d-x 2.2.5并没有相关的解密算法,所以需要修改若干文件方可正常使用,笔者修改后已测试成功,这里简单描述需要修改的内容。


quick-x 脚本及资源加解密方法修改文件(具体修改的地方对比一下就知道了)
一.资源解密修改
1.修改cocos2dx/platform/ios/CCImage.mm文件
2.增加文件 apptools 到 extensions 文件夹
3.给cocos2dx.xcodeproj添加header search path  : "$(SRCROOT)/../../extensions"


(注:这里笔者将apptools添加到了extensions文件夹只是为了方便,其实添加到其它位置也并非不可以。这里面涉及到了一点问题,因为cocos2dx的库文件位于cocos2dx.xcodeproj工程中,而lua库位于另外一个工程,但这一点在quick-x中不一样,在quick-x中这两个库文件都位于同一个工程,所以它们之间引用不存在问题,但是在cocos2d-x 2.2.5中便存在了不同工程间的文件引用问题,所以笔者此处做了2,3步的修改)。

二.脚本解密修改
1.修改lua/cocos2dx_support/CCLuaStack.h  .cpp 文件
2.增加 xxtea文件   目录 cocos2dx/support/xxtea.h  xxtea.c  
3.增加 CCZipFile.h .cpp文件    目录 cocos2dx/platform/CCZipFile.h  .cpp  
4.修改 unzip.h .cpp文件  目录cocos2dx/support/zip_support/unzip.h  .cpp 
5.增加 loapi_mem.h .cpp文件  目录 cocos2dx/support/zip_support/loapi_mem.h .cpp 


修改成功后,在cocos2d-x 2.2.5中也可以使用该加密方法了。


转自:http://blog.csdn.net/u012945598/article/details/38870705


本文转载自:http://blog.csdn.net/aa294194253/article/details/40746677

piggybear
粉丝 3
博文 237
码字总数 37552
作品 0
西安
技术主管
私信 提问
加载中

评论(0)

quick-cocos2d-x图片资源加密(续)

前篇: quick-cocos2d-x图片资源加密 让quick-cocos2d-x支持加密的plist文件 通过前篇的修改,我们已经能够在Windows平台的player,以及Android上使用加密的常见格式(png、jpg等)的图片资源了...

SunLightJuly
2014/01/03
5.1K
4
quick-cocos2d-x图片资源加密

quick-x已经支持用XXTEA加密方式对脚本文件进行加密。在此基础上,自己做了一些工作,对图片资源进行了XXTEA加密,现分享给大家。 (2014.5.30加注:quick-x的2.2.3版本已经集成了我递交的pr,...

SunLightJuly
2013/12/12
1.2W
28
quick-cocos2d-x源文件编译及加密详解

quick-cocos2d-x是用lua脚本来写的,而lua是明文形式,如果不对脚本进行处理,那么我们所写的代码将可能暴露给别人(apk和ipa都是简单的zip包装)。 quick-cocos2d-x框架为我们提供了一个可编...

lonewolf
2013/11/23
1.8W
43
QuickXDev增强功能:Compile Scripts(编译及加密源代码)

更新:此功能现在在mac和windows下都可用。 昨天弄清楚了编译和加密脚本的全部过程,今天我把这一功能集成到了QuickXDev,以方便广大开发者使用,详细使用方法如下: 1、 了解基本原理 Quic...

lonewolf
2013/11/24
4.6K
6
iMeteOra/cocos2d-x-qt

cocos2d-x-3.0alpha 中看到了Qt后端支持, 把它的.pro收纳囊肿! 其它的, 看有啥可以借鉴的吧. quick-cocos2d-x 是一个可以让您觉得“爽快”的 cocos2d-x 的扩展版。基于 cocos2d-x,完全的跨平...

iMeteOra
2014/04/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

【Flutter组件终结篇】332个组件 658页PDF

老孟导读:历时1年的时间,整理完成了330+组件的详细用法,不仅包含UI组件,还包含了功能性的组件。 虽然整理了 330+的组件基本用法,但并不是让你每一个都学习一遍,任何技术基本都是掌握 ...

老孟Flutter
52分钟前
17
0
三星手机又中招:一张壁纸可引发系统崩溃 附临时解决方法

  前几天国内有大量用户发现三星手机崩溃、黑屏或者无限重启, 这可能是三星手机的日历 APP 的 bug。这件事还没完,三星手机今天又发现了新的问题,换上一张特别的壁纸就会导致系统崩溃,不...

alkcendkljk
今天
13
0
查找当前目录和文件目录[重复] - Find current directory and file's directory [duplicate]

问题: This question already has answers here : 这个问题已经在这里有了答案 : How to properly determine current script directory? 如何正确确定当前脚本目录? (11 answers) (11个答...

技术盛宴
今天
27
0
你不知道的java对象序列化的秘密

简介 你知道序列化可以使用代理吗?你知道序列化的安全性吗?每个java程序员都听说过序列化,要存储对象需要序列化,要在网络上传输对象要序列化,看起来很简单的序列化其实里面还隐藏着很多...

flydean
今天
21
1
线程池

Java通过Executors提供四种线程池,分别为: newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。 newFixedThreadPool 创...

Joker上上签
今天
20
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部