日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內(nèi)最全I(xiàn)T社區(qū)平臺 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當(dāng)前位置:首頁 > php開源 > 綜合技術(shù) > cocos2dx游戲資源加密之XXTEA

cocos2dx游戲資源加密之XXTEA

來源:程序員人生   發(fā)布時間:2015-02-03 08:39:28 閱讀次數(shù):5623次

在手機(jī)游戲當(dāng)中,游戲的資源加密保護(hù)是1件很重要的事情。

我花了兩天的時間整理了自己在游戲當(dāng)中的資源加密問題,實現(xiàn)了跨平臺的資源流加密,這個都是偉人的肩膀之上的。在手機(jī)游戲資源加密這塊,能做到安全加密保護(hù)的確切不多,有研究過專業(yè)平臺愛加密的手機(jī)游戲加密解決方案,有興趣的可以點此了解:http://www.ijiami.cn/appprotect_mobile_games

大概的思路是這樣的,游戲資源通過XXTEA加密方法對流的加密方式,有自己的密鑰和標(biāo)識,通過標(biāo)識可知是不是有加密,密鑰是自己程序當(dāng)中的。除非有密鑰,否則很難通過解出正確的文件。經(jīng)過加密后,加密文件也就是游戲資源放在resource的自己文件夾中,否則在xcode編譯到趁機(jī)是會辨認(rèn)不了文件。在程序中cocos2dx底層加入解密進(jìn)程,就能夠把文件正確讀取出來,讓程序顯示。經(jīng)實驗,已可以讀取,png,plist,json文件。

現(xiàn)在記錄下實現(xiàn)的步驟

鏈接: http://pan.baidu.com/s/1ntx98VZ 密碼: qyqe 去下載加密資源的腳本,這個是quick-cocos2d-x提取出來的打包工具。

pack_files.sh -i olddir -o newdir -ek XXTEA -es decodetest

把ResourcesDecode和xxtea4個文件加入到cocos2dx/platform下;

把platform/ResourcesDecode.cpp
platform/xxtea.c 加入到cocos2dx/platform的android.mk文件中,加入android編譯。

寫1個單例用來保存密碼和對流解密進(jìn)程,代碼以下:

<span style="font-family:Arial;font-size:14px;">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;</span>

buffer就是經(jīng)過XXTEA解密后正確的流。

在CCFileUtils::getFileData()當(dāng)中return返回之前調(diào)用解密pBuffer =ResourcesDecode::sharedDecode()->decodeData(pBuffer, size, pSize);這里是跨平臺的讀取資源的方法。

在ZipFile::getFileData()當(dāng)中也加入解密方法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的修改地方 不1樣

在CCFileUtilsIOS中的createCCDictionaryWithContentsOfFile修改以下,注釋掉的是本來的,后面是新增的。

<span style="font-family:Arial;font-size:14px;">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];</span>

在CCImage.mm當(dāng)中修改,一樣是注釋是本來的,后面是新增的。

<span style="font-family:Arial;font-size:14px;">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];</span>

android平臺

在CCImageCommon_cpp當(dāng)中修改以下

<span style="font-family:Arial;font-size:14px;">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);</span>

到此,基本結(jié)束了。

在自己程序當(dāng)中加入資源前把設(shè)置密鑰和標(biāo)識和自己加密資源時的1樣:ResourcesDecode::sharedDecode()->setXXTeaKey("XXTEA",strlen("XXTEA"),"decodetest",strlen("decodetest"));

其它就正常的讀取和顯示。

生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關(guān)閉
程序員人生
主站蜘蛛池模板: 久久天堂网| 日韩二区三区 | 簧片av| 天堂在线免费观看 | 国产一区二区在线免费观看 | 色网在线 | 久久久久国产一区二区三区四区 | 美女视频一区 | 久久国产精品一区二区三区 | av第下页 | 国内精品国产三级国产在线专 | 视频一区二区三区在线观看 | 欧美激情综合五月色丁香小说 | 国产尤物视频 | 国产精品第一国产精品 | 亚洲一区二区精品在线 | 最新国产精品精品视频 | 国产一区二区三区视频播放 | 欧美午夜精品一区二区蜜桃 | 欧美巨猛xxxx猛交黑人97人 | 在线精品一区 | 国产精品二区三区 | 欧美日韩一二区 | 成人在线日韩 | 久久久www成人免费无遮挡大片 | 亚洲精品福利电影 | 男女爱爱免费视频 | 日韩免费看片 | 三级网站 | 亚洲一二三四区 | 午夜精品视频 | 久久一区精品 | 日韩av在线一区二区三区 | 天堂网在线视频 | 国产日韩一区二区三区 | 亚洲成人国产 | 国产精品久久久久久久久久尿 | 国产精品一区二区av | 国产香蕉视频在线 | 日韩一级片在线播放 | 久久久久成人精品 |