cocos2dx资源和脚本加密quick-lua3.3final

一、资源加密

版本号:Quick-Cocos2d-x 3.3 Final

调试工具:xCode

工程创建的时候选择的拷贝源码。

项目结构如图:

这个功能七月大神在很早之前就已经实现了,但是在3.3版本中有几个小BUG,可能很多人不知道一直卡住了。我就在这儿从头到尾的流程都讲一次。

道理很简单 主要就只用到quick-src/extra/approols/下面的HelperFunc这个类。

我只做了图片的加密,plist未做。道理一样。我就只说图片的吧。

第一步

1.  由于cocos现在统一了资源读取,所以,找到CCImage.ccp这个类,导入HelperFunc头文件


1

#include "extra/apptools/HelperFunc.h"

这个时候重要的来了,xcode报错。提示HelperFunc.h找不到。我查了半天最后才发现问题所在,原来是searchpath的路径官方填错了。按照图片步骤,添加quick-src的搜索路径

$(SRCROOT)/../../runtime-src/Classes/quick-src

这个时候,错误应该就消失了。

2.找到 initWithImageFile 这个函数

修改


1

Data data = FileUtils::getInstance()->getDataFromFile(_filePath);

为:


1

 Data data = HelperFunc::getData(_filePath);

这一步就是读取资源的时候通过七月大神封装好的类来解密。

第二步

这个时候android是编译不过去的。跟上面一样提示 找不到HelperFunc。

可以通过改mk文件来处理。按照路径:

你的项目/frameworks/cocos2d-x/cocos/Android.mk

打开mk,在如图的位置添加quick-src的搜索路径

$(LOCAL_PATH)/../../runtime-src/Classes/quick-src/

一定要注意格式哦。上面一行末尾如果没有 需要添加一个“\”

第三步

接下来就是加密图片了。

在引擎目录下/quick/bin/下面 有个pack_files.sh 我们就是用到这个东西来加密了。这个跟lua加密差不多。我简单说一下流程。

1.写一个配置文件.php的。很简单。

切记 记好你的key和签名!!!后面还会用到。

我比较懒,没有新写一个demo。用的项目的,所以关键部位*****。不过不重要。忘谅解。

2.终端执行 pack_files.sh -c 你的php路径.php 如果没有报啥错,这一步就算完成了。我的输出路径填的就是项目res下。如果不是,把加密好的图片拷贝覆盖进去就OK。

第四步

最后在AppDelegate.ccp 添加:

stack->setXXTEAKeyAndSign("你的key", strlen("你的key"), "你的签名", strlen("你的签名"));

到了这一步,基本大功告成了。跑起来试试吧。真机哦。如果想要在模拟器上也支持加密,需要打开player项目 重复第一步 第四部照做一次,再编译一个player。

二、脚本加密

如果只是实现加密,这个更简单了。

在引擎目录下/quick/bin/下面 compile_scripts.sh  这个东西就是我们需要的。他接受好几种加密方式,我一般只用到xxtea_zip 和 xxtea_chunk 这两种。前一种是把lua脚本压缩成一个zip,为这个zip加密。后一种是为每个脚本加密,然后再压缩一次。都差不多。

终端进入 /quick/bin/这个目录,执行 ./compile_scripts.sh -i 你的脚本的目录(比如我的/Users/bkbl/Documents/game/src) -o 加密后文件的输出目录(比如我的/Users/bkbl/Documents/game/res/game.zip) -e (加密方式 xxtea_chunk 或者 xxtea_zip ) -es 签名(比如 XXTEA) -ek 密钥(也就是KEY 比如 adadada) 

只要代码没错误,这儿也不会报错。我的输出路径是我项目res下。如果不是 拷贝进去。

最后在AppDelegate.ccp 添加

stack->setXXTEAKeyAndSign("你的key", strlen("你的key"), "你的签名", strlen("你的签名"));

比如:


1

stack->setXXTEAKeyAndSign("adadada"strlen("adadada"), "XXTEA"strlen("XXTEA"));

读取这个zip


1

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

修改下面


1

engine->executeScriptFile(ConfigParser::getInstance()->getEntryFile().c_str());

的函数为


1

stack->executeString("require ‘main‘");

搞定!!!非常傻瓜式的。再次感谢Quick团队!

如果你同时做了脚本和资源加密 一定要用一套key和签名的。切记!!!

时间: 2024-11-05 12:28:43

cocos2dx资源和脚本加密quick-lua3.3final的相关文章

Quick-Cocos2d-x Lua脚本加密学习

学习记录一下: 具体看实际操作. 使用cygwin 或者 git 进入shell脚本模式,进入你的项目文件夹: 大概是在:D:\quick-cocos2d-x\bin\yourProject 执行命令: ../compile_scripts.sh -i scripts -m files -o my_scripts <执行编译shell,输入scripts文件夹里面的.lua文件,编译模式是编译成文件,编译输出文件夹是my_scripts> 开始编译了. 如果出现了错误,根据错误,解决排除错误.

sch 助shell脚本加密 02

sch 助shell脚本加密 02 一.  简介 SHC(shell script compiler),即shell脚本编译器.通过SHC编译过的脚本对普通用户而言是不可读的,因此如果你想让你的代码实现加密功能,让其有效的屏蔽一些敏感信息,这个时候可以考虑使用SHC:它通常情况下是不太容易被破解的,但是还是有些人可以通过反编译SHC的方法来实现破解加密过的脚本. 二.  实验测试开始 2.1 下载并编译SHC [[email protected] ~]# wget http://www.dats

vbs脚本加密

vbs脚本加密使用screnc程序,它可以加密asp文件.html文件.js,vbs,sct,wsh文件 加密操作 d:\>screnc.exe d:\vbs\sendmail.vbs d:\vbs\sendmail.vbe d:\>dir d:\vbs 驱动器 D 中的卷是 本地磁盘 卷的序列号是 BAD9-2574 d:\vbs 的目录 2016/12/23  14:15    <DIR>          . 2016/12/23  14:15    <DIR>

破解JS脚本加密

有时候一些html内容被加密了,我们看不到这些内容:) 下面选取了2种破解JS脚本加密的方式,大家看看 对于HTML加密或限制来说参考下面的方法www.82676666.com zzzevazzz 写的破大部分加密,显源码的东东,在地址栏输入: javascript:s=document.documentElement.outerHTML;document.write('');document.body.innerText=s; 对于JS加密来说参考下面的方法 最近很多人在问加密代码的问题.其实

[cocos2d-x] 资源json的载入过程

这块代码主要是文件CCSGUIReader   CCSGUIReader 的作用是解析json组合成用户需要的UIWiget对象. 实例: Widget* m_uiRoot = cocostudio::GUIReader::shareReader()->widgetFromJsonFile("fruit_ui_1.json"); -> 往下面走 return widgetFromJsonDocument(jsonDict, fileName, NULL); jsonDict

iOS项目冗余资源扫描脚本

iOS项目冗余资源扫描脚本 随着iOS项目的版本不断迭代,app中冗余文件会越来越多,app size也持续增加,是时候需要对app冗余资源进行检测,对app进行瘦身. 使用方法: 1. 运行环境为mac, 首先准备好工程源代码: 2. 新建check.sh,将下面的代码粘贴到check.sh中并且保存:(可将txt文件改成sh后缀) #!/bin/sh ##### several cases that the scripts does not work: ##### 1) there is s

gzexe 助shell脚本加密 01

gzexe 助shell脚本加密 01 一.  简介 很多时候我们的脚本会涉及到一些私密的信息,例如:用户名,密码,或者其它重要信息的时候,我们使用一些加密的手段来屏蔽这些信息,确保系统的安全已经脚本的可流传性,通常情况下我们只需要通过系统自带的gzexe这个工具就够了. 二.         实验测试开始: 2.1 编写一个用于测试的脚本 [[email protected] ~]# vi woo.sh #! /bin/ksh echo 'PrudentWoo'' '`date +%Y-%m-

如何解决xcode里开发cocos2dx修改lua脚本后不刷新的问题

用xcode来开发cocos2dx,结果发现一个很纠结的问题,如果我一旦修改了一个Lua文件,我必须clean之后再build,否则修改的Lua文件不会体现出来.这是一个很令纠结的结果,特别是我要进行调试的时候,在网上搜索了一圈,发现xcode原来可以提供一个build phase的功能,允许在build中间执行一些脚本,而这个时候只要将脚本文件touch一下就可以解决问题,但是比较奇怪的是,如果是touch Resources文件是不行的,必须touch Resources目录下的某个文件.

手机游戏加密那点事儿_2d脚本加密

最近有一位朋友求助我,他问我关于单片机你知道多少?我说啥也不知道.他就说不行,你帮我写一写关于单片机的一篇文章,题目就是你身边的单片机.这可真是累死我呀,我根本不知道啥是单片机呀!无奈之下,只得网上搜集资料了.经过一点时间的搜索,我发现我又增加了些知识,因为我对单片机了解了一点,虽然仅仅是一点而已. 于是写下来,供读者参考参考,写的不好还请原谅哈.以下是正文: 随着科技的进步与社会的发展,我们的生活越来越丰富多彩.其中有很多非常先进的一些东西改变了我们的生活,有手机,电脑,电视,电话,单片机等等