cocos2dx游戏资源加密之XXTEA
在手机游戏当中,游戏的资源加密保护是一件很重要的事情。
我花了两天的时间整理了自己在游戏当中的资源加密问题,实现了跨平台的资源流加密,这个都是巨人的肩膀之上的。
大概的思路是这样的,游戏资源通过XXTEA加密方法对流的加密方式,有自己的密钥和标识,通过标识可知是否有加密,密钥是自己程序当中的。除非有密钥,否则很难通过解出正确的文件。经过加密后,加密文件也就是游戏资源放在resource的自己文件夹中,否则在xcode编译到趁机是会识别不了文件。在程序中cocos2dx底层加入解密过程,就可以把文件正确读取出来,让程序显示。经试验,已经可以读取,png,plist,json文件。
现在记录下实现的步骤
链接: http://pan.baidu.com/s/1ntx98VZ 密码: qyqe 去下载加密资源的脚本,这个是quick-cocos2d-x提取出来的打包工具。
pack_files.sh -i olddir -o newdir -ek XXTEA -es decodetest
把ResourcesDecode和xxtea四个文件加入到cocos2dx/platform下;
把platform/ResourcesDecode.cpp \
platform/xxtea.c \加入到cocos2dx/platform的android.mk文件中,加入android编译。
写一个单例用来保存密码和对流解密过程,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
CCAssert(buf != NULL, "decodeData buf not NULL" );
unsigned char * buffer = NULL;
ResourcesDecode* decode = ResourcesDecode::sharedDecode();
bool isXXTEA = decode && decode->m_xxteaEnabled;
for (unsigned int i = 0; isXXTEA && i < decode->m_xxteaSignLen && i < size; ++i)
{
isXXTEA = buf[i] == decode->m_xxteaSign[i];
}
if (isXXTEA)
{
//decrypt XXTEA
xxtea_long len = 0;
buffer = xxtea_decrypt(buf+decode->m_xxteaSignLen, (xxtea_long)size -(xxtea_long)decode->m_xxteaSignLen, (unsigned char *)decode->m_xxteaKey, (xxtea_long)decode->m_xxteaKeyLen, &len);
delete [] buf;
buf = NULL;
size = len;
}
else
{
buffer = buf;
}
if (pSize)
{
*pSize = size;
}
return buffer;
|
buffer就是经过XXTEA解密后正确的流。
在CCFileUtils::getFileData()当中return返回之前调用解密pBuffer =ResourcesDecode::sharedDecode()->decodeData(pBuffer, size, pSize);这里是跨平台的读取资源的方法。
在ZipFile::getFileData()当中也加入解密方法pBuffer =ResourcesDecode::sharedDecode()->decodeData(pBuffer, fileInfo.uncompressed_size, pSize);这个是android读取plist的地方,我也不太清楚为什么android会在这里读取资源。
在bool CCSAXParser::parse(const char *pszFile)中把原先的rt改为rb : char* pBuffer = (char*)CCFileUtils::sharedFileUtils()->getFileData(pszFile,/*"rt"*/"rb", &size);
ios的修改地方 不一样
在CCFileUtilsIOS中的createCCDictionaryWithContentsOfFile修改如下,注释掉的是原先的,后面是新增的。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
CCDictionary* CCFileUtilsIOS::createCCDictionaryWithContentsOfFile( const std::string& filename)
{
std::string fullPath = CCFileUtils::sharedFileUtils()->fullPathForFilename(filename.c_str());
// NSString* pPath = [NSString stringWithUTF8String:fullPath.c_str()];
// NSDictionary* pDict = [NSDictionary dictionaryWithContentsOfFile:pPath];
unsigned long fileSize = 0;
unsigned char * pFileData = CCFileUtils::sharedFileUtils()->getFileData(fullPath.c_str(), "rb" , &fileSize);
NSData *data = [[[NSData alloc] initWithBytes:pFileData length:fileSize] autorelease];
delete []pFileData;
NSPropertyListFormat format;
NSString *error;
NSMutableDictionary *pDict = (NSMutableDictionary *)[
NSPropertyListSerialization propertyListFromData:data
mutabilityOption:NSPropertyListMutableContainersAndLeaves
format:&format
errorDescription:&error];
|
在CCImage.mm当中修改,同样是注释是原先的,后面是新增的。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
static bool _initWithFile( const char * path, tImageInfo *pImageinfo)
{
CGImageRef CGImage;
UIImage *jpg;
UIImage *png;
bool ret;
// convert jpg to png before loading the texture
// NSString *fullPath = [NSString stringWithUTF8String:path];
// jpg = [[UIImage alloc] initWithContentsOfFile: fullPath];
unsigned long fileSize = 0;
unsigned char * pFileData = cocos2d::CCFileUtils::sharedFileUtils()->getFileData(path, "rb" , &fileSize);
NSData *adata = [[NSData alloc] initWithBytes:pFileData length:fileSize];
delete []pFileData;
jpg = [[UIImage alloc] initWithData:adata];
|
android平台
在CCImageCommon_cpp当中修改如下
1
2
3
4
5
6
7
8
|
bool CCImage::initWithImageFileThreadSafe( const char *fullpath, EImageFormat imageType)
{
bool bRet = false ;
unsigned long nSize = 0;
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
CCFileUtilsAndroid *fileUitls = (CCFileUtilsAndroid*)CCFileUtils::sharedFileUtils();
// unsigned char *pBuffer = fileUitls->getFileDataForAsync(fullpath, "rb", &nSize);
unsigned char * pBuffer = CCFileUtils::sharedFileUtils()->getFileData(fullpath, "rb" , &nSize);
|
到此,基本结束了。
在自己程序当中加入资源前把设置密钥和标识和自己加密资源时的一样:ResourcesDecode::sharedDecode()->setXXTeaKey("XXTEA",strlen("XXTEA"),"decodetest",strlen("decodetest"));
其它就正常的读取和显示。
参考网址:http://my.oschina.net/SunLightJuly/blog/184061
http://my.oschina.net/SunLightJuly/blog/189971
http://my.oschina.net/SunLightJuly/blog/184179
cocos2dx游戏资源加密之XXTEA相关推荐
- Cocos2d-x客户端资源加密
安卓打包的apk文件只是做了简单的压缩,通过解压缩可以获取资源文件,如果不想图片资源被别人看到,那么可以对图片进行加密. cocos2d-x提供了xxtea加密和解密算法,先将图片进行加密,这样就打不 ...
- Cocos2d-x 资源加密解密实践总结
本文乃Siliphen原创,转载请注明出处:http://blog.csdn.net/stevenkylelee 本文针对的是cocos2d-x 3.4 版本进行研究. 做加密解密的思路 加密解密算法 ...
- 游戏资源差异化热更新及加密全攻略(Assetbundle 打包 AssetBundle 加载 AssetBundle 加密)
游戏热更新资源加密的必要性 unity中资源热更新还是Assetbundle为主,资源使用越来越广泛,ab包里可以包含图片.视频或者脚本,都是游戏的知识财产,如果被破解者或者竞争对手解开,拿到里面的内 ...
- 游戏解包的危害及资源加密的重要性
细分赛道中的"香饽饽"--乙女游戏 据咨询公司弗若斯特沙利文的市场分析报告,2013-2017年,中国女性手机游戏的市场规模按收益计,年复合增长达101.6%:预计2022年,中国 ...
- CocoStudio游戏发布后资源加密大致实现思路
截 止到目前,CocoStudio版本已经发展到1.5,各个子工具间也已经发生了巨大变化.但是,无论是动画编辑器,UI编辑器,场景编辑器还是 数据编辑器,它们生成(导出)的文件在商业开发中往往需要进行 ...
- Quick 3.3 的代码资源加密
http://cn.cocos2d-x.org/tutorial/show?id=1507 http://cn.cocos2d-x.org/tutorial/show?id=1447 http://b ...
- 疫情期间自我修炼, 搞一搞老游戏资源解包
疫情期间自我修炼, 准备搞一搞老游戏资源解包, 修旧利废,聊以自慰.首先对不住的是大雨资讯的<大富翁>系列,挑了几个感兴趣的解包完毕: 1-3是DOS版,没什么好看. 4太难看,决定从5开 ...
- Cocos2dx游戏开发系列笔记6:怎样让《萝莉快跑》的例子运行在vs和手机上
2019独角兽企业重金招聘Python工程师标准>>> 感谢听D同学赞助的Demo. 那怎样让它运行在vs中呢: 1 使用cocos2d-x-2.2\tools\project-cr ...
- 转:Unity3D研究院之提取游戏资源的三个工具支持Unity5(八十四)
这两天无意间又发现了两个提取Unity游戏资源的工具,这会儿刚好有时间我就码点字总结一下. 一.disunity 因为之前写过了所以这里就不介绍了 .Unity3D研究院之mac上从.ipa中提取un ...
最新文章
- 《虚拟化与云计算》读书感(四)数据中心的设计和构造
- 史上最简单的SpringCloud教程 | 第十篇: 高可用的服务注册中心
- 视频压缩标准简史:从1929到2020
- python gif_python 将png图片格式转换生成gif动画
- ios7自定义返回按钮后,右滑返回功能失效解决方法
- SCPPO(二十五):从导数据看如何将一天过出多天的效果
- 彐一夕儿本铺_2019-10-16汉字宫目录
- 解决fegin post requestbody 400报错问题
- (面经)微信群发红包后,怎么判断抢的与发的钱数一致
- 靶向药物丨艾美捷西妥昔单抗Cetuximab方案
- Java-Tomcat的请求参数解析分析
- 全排列(下一个排列,算法)
- 【读书笔记】金字塔原理-构建金字塔的逻辑顺序
- 学习web的多个连接网站地址
- vue+echarts+自适应 实现可视化大屏展示效果
- SpringMVC的 transferTo使用
- STC12C5A60S2系列单片机PCA时钟源设置
- 图吧为什么叫图拉丁_如何评价百度贴吧「图拉丁吧」?
- 计算机的清屏,计算机清屏键是什么
- 洛谷 P1914.小书童——密码