quick cocos2dx脚本加密

转载 2016年06月01日 17:18:20

如果开发者不想让游戏中的资源或脚本文件轻易的暴露给其他人,一般会采用对文件进行加密的方式来保护文件或资源被盗用。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 -ek MYKEY -es XT

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

1409824784805447.png

下面打开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查看帮助

1409824907818140.png

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

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

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

如果将资源压缩成了zip包,还需再加一行代码:

1
pStack->loadChunksFromZip("picture.zip");

如此便可以成功运行了,打包时在项目的资源中仅保留.zip即可,原本的资源及脚本直接删除其引用即可,源文件千万不要删掉(只要把asserts中lua文件删掉就可以了)。





详解Quick-Cocos2d-x 加密

本文开发环境:Xcode 5.0 + Quick-Cocos2d-x v2.2.5 如果开发者不想让游戏中的资源或脚本文件轻易的暴露给其他人,一般会采用对文件进行加密的方式来保护文件或资源被盗用。Q...
  • linking530
  • linking530
  • 2015年01月21日 11:16
  • 1111

quick-3.5 打包加密的个人总结

对于quick-lua打包问题,在网上有很多文章介绍。可到了quick-lua 3.5 框架有很大的变化,以前的都不适用了。 最近从网上找了一些资料,总结记录下来 ,仅供个人参考 ###加密###...
  • xue_huashan
  • xue_huashan
  • 2015年08月07日 18:18
  • 1225

quick-cocos2dx-v3加密脚本文件

Compile_scripts详细参数 -h 帮助 -i  源文件目录 -o 输出文件目录/输出文件名 -p 包前缀名字 -x  不包含的包,即当前目录下的哪些包不希望被添加进去 -m 编...
  • zlQQhs
  • zlQQhs
  • 2014年09月17日 21:01
  • 5671

cocos2dx 3.4 lua加密 和 解密

1.在自己项目的根目录下按住Shift键, 右击鼠标, 点击“在此处打开命令窗口” 然后输入 cocos luacompile -s src/ -d out/ -e -k...
  • aizhiqiang2
  • aizhiqiang2
  • 2016年07月20日 09:48
  • 1946

cocos2dx-lua 3.4 之 图片资源加密!

一、前言 1.我将要给大家分享的是XXTEA加密方式,对图片资源进行加密。 2.需要工具:quick-lua中已经集成图片加密工具,但是我没有用quick,所以单独把这个加密文件夹拎出来了。点击下载...
  • zwcwu31
  • zwcwu31
  • 2017年01月11日 16:21
  • 703

cocos2dx lua XXTEA来加密解密实现详解

cocos2dx lua已经集成了对lua脚本的加解密,见AppDelegate.cpp     LuaStack* stack = engine->getLuaStack();     s...
  • huiming120
  • huiming120
  • 2016年08月17日 10:54
  • 1184

cocos2dx游戏资源加密之XXTEA

在手机游戏当中,游戏的资源加密保护是一件很重要的事情。 我花了两天的时间整理了自己在游戏当中的资源加密问题,实现了跨平台的资源流加密,这个都是巨人的肩膀之上的。 大概的思路是这样的,游戏资源通过X...
  • dingkun520wy
  • dingkun520wy
  • 2015年11月14日 11:51
  • 4365

cocos2dx 3.xLua脚本加密解密

使用LUA脚本开发游戏有着诸多的优势,动态更新,不需要考虑内存和数据类型等等。但是LUA脚本的安全性问题却似的许多开发者非常苦恼。 我这两天因为LUA脚本加密的问题苦恼了好久,经过了两天的努力,...
  • ganpengjin1
  • ganpengjin1
  • 2016年03月30日 10:13
  • 1656

cocos lua 加密与解密 混淆 (版本cocos3.4)

cocos luacompile cocos luacompile OverviewUsageAvailable ArgumentsSamples Overview Compile the .l...
  • Kaitiren
  • Kaitiren
  • 2015年03月19日 14:17
  • 14463

cocos2dx lua 加密

cocos2dx lua 加密
  • cloud95
  • cloud95
  • 2014年07月25日 10:29
  • 9846
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:quick cocos2dx脚本加密
举报原因:
原因补充:

(最多只允许输入30个字)