Coco2d-x引擎是相对于Unity3D的又一实力派引擎。尽管随着3D游戏的热门,很多其它的厂商偏向于Unity3D。可是Coco2d-x的普及量也不容小觑,特别是一些比較大的手游公司。比方触控科技仍然一直沿用着Coco2d-x的东西。我们从三个热门游戏来说说Coco2d-x游戏的一般文件验证方法。
1、捕鱼达人2:将Smali文件里获取包路径的參数转向我们自己定义的。
该种方法最早见于:http://bbs.csdn.net/topics/390598569?page=2#post-395954285

居然闪退那必定会在主Activity的oncreate中启动相关代码。以下是流程:

public class FishingJoy extends FishingJoyWrapper-->public class FishingJoyWrapper extends Cocos2dxActivity-->public abstract class Cocos2dxActivity extends Activity。

注意:class A extends B 表示A类承接B类,即B是A的相对父类。

从而知 Cocos2dxActivity 是程序启动时的根类。查看 oncreate 方法:

  protected void onCreate(Bundle paramBundle)
{
super.onCreate(paramBundle);
init();
Cocos2dxHelper.init(this, this);
}

又转向至 Cocos2dxHelper 类的 init 方法中,以下是其基本的smali代码:

<pre name="code" class="javascript">    //“參考文章:http://android.tgbus.com/Android/tutorial/201108/362210.shtml”
//通过ApplicationInfo类中的packageName方法获取程序名称并保存在sPackageName字符串中
iget-object v1, v0, Landroid/content/pm/ApplicationInfo;->packageName:Ljava/lang/String;
sput-object v1, Lorg/cocos2dx/lib/Cocos2dxHelper;->sPackageName:Ljava/lang/String;
//通过ApplicationInfo类中的sourceDir方法获取APK程序的路径,并传递给native层
iget-object v1, v0, Landroid/content/pm/ApplicationInfo;->sourceDir:Ljava/lang/String;
invoke-static {v1}, Lorg/cocos2dx/lib/Cocos2dxHelper;->nativeSetApkPath(Ljava/lang/String;)V

通过以上分析我们非常easy得出,仅仅需将获取APK路径的v1转向原版的APK就可以绕过程序的校验。代码改动为:

    iget-object v1, v0,Landroid/content/pm/ApplicationInfo;->sourceDir:Ljava/lang/String;
const-string v1, "/sdcard/buyudaren.apk"
invoke-static {v1}, Lorg/cocos2dx/lib/Cocos2dxHelper;->nativeSetApkPath(Ljava/lang/String;)V

须要的操作是将原版apk更名为buyudaren.apk放在sdcard的根文件夹就可以。

2、我是车神 Ver1.2.6:将Smali文件里获取包路径的參数转向其它的就可以。

分析的流程是于捕鱼达人2一样的,知道这样我们能够直接搜索关键词“->sourceDir:”。出现两个结果,例如以下图:

事实上。经过以外的測试。发现原来仅仅须要将路径转向即可。不必要真的在指定位置放个原版。猜測的推断是文件不存在时。走的流程还是推断正确的逻辑。不得不说这是开发人员的一大失误啊。

3、保卫萝卜 Ver1.2.0:

这个游戏总体反编译apk的时候 会出现错误,貌似是资源文件的问题,可是我们能够直接拖出dex反编译。



相同是直接搜索“->sourceDir:”,然后将路径指定即可。

总结

就像曾经在博客中说的,假设不正确apk进行加壳或者利用第三方进行防护的话。apk本身的校验貌似真的仅仅有签名校验和对文件的合法性进行验证。

不管是在smali、so还是dll。签名关键词“signature”或者“publickey”。pubkey 关键词的会获取一串MD5的值;

.method public static getSign(Landroid/content/Context;)Ljava/lang/String;
.locals 6
.param p0, "context" # Landroid/content/Context;
//########################以下是签名校验的部分###########################
 .prologue
.line 374
//初始化v4为空
const-string v4, ""
//读取com/txbnx/torrentsearcher/Utils方法中的mPublicKey字符串 赋给v5
sget-object v5, Lcom/txbnx/torrentsearcher/Utils;->mPublicKey:Ljava/lang/String;
//推断v4,v5是否相等 并返回为v4布尔值
invoke-virtual {v4, v5}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v4 if-nez v4, :cond_0 .line 375
sget-object v4, Lcom/txbnx/torrentsearcher/Utils;->mPublicKey:Ljava/lang/String; .line 385
:goto_0
return-object v4 .line 376
:cond_0
//引用获取已安装包信息的方法getPackageManager()
invoke-virtual {p0}, Landroid/content/Context;->getPackageManager()Landroid/content/pm/PackageManager; move-result-object v2 .line 378
.local v2, "pm":Landroid/content/pm/PackageManager;
:try_start_0
//获取包名字符串并保存在v4中
invoke-virtual {p0}, Landroid/content/Context;->getPackageName()Ljava/lang/String; move-result-object v4 const/16 v5, 0x40 invoke-virtual {v2, v4, v5}, Landroid/content/pm/PackageManager;->getPackageInfo(Ljava/lang/String;I)Landroid/content/pm/PackageInfo; move-result-object v1 .line 380
.local v1, "packageinfo":Landroid/content/pm/PackageInfo;
//获取包信息里面的签名
iget-object v4, v1, Landroid/content/pm/PackageInfo;->signatures:[Landroid/content/pm/Signature; const/4 v5, 0x0 aget-object v3, v4, v5 .line 382
.local v3, "sign":Landroid/content/pm/Signature;
//将签名信息转换为字符串 并保存在v4寄存器中
invoke-virtual {v3}, Landroid/content/pm/Signature;->toCharsString()Ljava/lang/String; move-result-object v4 sput-object v4, Lcom/txbnx/torrentsearcher/Utils;->mPublicKey:Ljava/lang/String; .line 383
sget-object v4, Lcom/txbnx/torrentsearcher/Utils;->mPublicKey:Ljava/lang/String;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 .line 384
.end local v1 # "packageinfo":Landroid/content/pm/PackageInfo;
.end local v3 # "sign":Landroid/content/pm/Signature;
:catch_0
move-exception v0 .line 385
.local v0, "e":Ljava/lang/Exception;
const/4 v4, 0x0 goto :goto_0
.end method
    .local v0, "pubkeyMd5":Ljava/lang/String;
const-string v1, "SigntureUtil"
//##########################################以下是利用pubkey关键词校验的代码########################################
new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V const-string v3, "pubkeyMd5:" invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; move-result-object v2 invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v2 invoke-static {v1, v2}, Lcn/com/cmbc/mbank/Log;->i(Ljava/lang/String;Ljava/lang/String;)V .line 68
if-eqz v0, :cond_0 const-string v1, "e6a81c9a3c88040678ae615f063d14d0" invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v1 const/4 v1,0x1

文件检验首先是获取文件的路径,或者直接文件名称,关键词“classes.dex”或者“->sourceDir:”,后者获取路径以后会传入其它的方法进行验证,如so方法。

    iget-object v7, v13, Landroid/content/pm/ActivityInfo;->packageName:Ljava/lang/String;
//获取文件路径
iget-object v8, v14, Landroid/content/pm/ApplicationInfo;->sourceDir:Ljava/lang/String;
const-string v8, "/sdcard/woshicheshen.apk" //路径转向
sget v9, Landroid/os/Build$VERSION;->SDK_INT:I

里面里面会有非常多的错误之处。望大牛们不吝指出啊。不让让我以讹传讹啊 我要进步..

Cocos2d-x游戏的一般验证分析的更多相关文章

  1. 4、Cocos2dx 3.0三,找一个小游戏开发Hello World 分析

    尊重开发人员的劳动成果.转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/27186557 Hello World 分析 打开新 ...

  2. Cocos2d—X游戏开发之CCToggle(菜单标签切换)CCControlSwitch(开关切换)

    Cocos2d—X游戏开发之CCToggle(菜单标签切换) 首先继承子CCMenu,是菜单标签中的一种.‘ class CC_DLL CCMenuItemToggle : public CCMenu ...

  3. iOS cocos2d 2游戏开发实战(第3版)书评

    2013是游戏爆发的一年,手游用户也是飞速暴增.虽然自己不做游戏,但也是时刻了解手机应用开发的新动向.看到CSDN的"写书评得技术图书赢下载分"活动,就申请了一本<iOS c ...

  4. QQ空间玩吧HTML5游戏引擎使用比例分析

    GameLook报道/“Cocos 2015开发者大会(春季)”于4月2日在国家会议中心圆满落下帷幕.在会上全新的3D编辑器,Cocos Runtime等产品重磅公布,给业界带来了Cocos这款国产引 ...

  5. php开发面试题---游戏面向对象设计与分析实例

    php开发面试题---游戏面向对象设计与分析实例 一.总结 一句话总结: 不要光空想,多看几个实例就知道自己的游戏该怎么设计了 根据实例去理解面向对象编程的的六大原则 1.英雄种类分别有:战士.法师. ...

  6. 比特币区块结构Merkle树及简单支付验证分析

    在比特币网络中,不是每个节点都有能力储存完整的区块链数据,受限于存储空间的的限制,很多节点是以SPV(Simplified Payment Verification简单支付验证)钱包接入比特币网络,通 ...

  7. 第二次作业-关于Steam游戏平台的简单分析

    1.1 Steam平台的简单介绍 你选择的产品是? 如题,这次的作业我选择了Steam作为分析的对象. 为什么选择该产品作为分析? 我选择数字游戏贩售平台STEAM作为分析对象的原因有以下几点: 1. ...

  8. thinkphp自动验证分析

    thinkphp有一个自动验证的方法验证规则如下 array( array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]), array(验证字段2,验证规则,错误提示,[验证条件 ...

  9. 潭州课堂25班:Ph201805201 django 项目 第十一课 手机号是否存在,短信验证分析 (课堂笔记)

    判断手机号是否注册功能实现 1.分析 请求方法:GET url定义:/mobiles/(?P<mobile>1[3-9]\d{9})/ 请求参数:url路径参数 参数 类型 前端是否必须传 ...

随机推荐

  1. Attribute(一)——提前定义特性

    在项目中接触到了Attribute,那么什么是Attribute,有些什么作用呢?这里来了解一下. 一.什么是Attribute Attribute 类将提前定义的系统信息或用户定义的自己定义信息与目 ...

  2. ACM:动态规划,01背包问题

    题目: 有n件物品和一个容量为C的背包.(每种物品均仅仅有一件)第i件物品的体积是v[i],重量是w[i].选一些物品装到这个背包中,使得背包内物品在整体积不超过C的前提下重量尽量大. 解法:两种思路 ...

  3. less09 判断语句

    less //.mixin (@a) when (lightness(@a) >= 50%) { //255/2=127.5 // background-color: black; //} // ...

  4. xp秘钥

    TDCXC-M9FW9-3HQ28-CPXYR-YXQ3QCCBDF-9W9T8-K8B7M-83HJM-X2MCWP3MF6-BTDKT-KR7YF-X4BM9-4HD9TMCCWF-42JGF-W ...

  5. CUDA笔记(11)

    CUDA提供了一种cudaEvent_t的类型,这种类型Event可以统计GPU上面某一个任务或者代码段的精确运行时间 使用常量内存的光线跟踪器的性能比使用全局内存的性能提升了50% __consta ...

  6. 四、YOLO-V1原理与实现(you only look once)

    可以看成图像分类与定位的结合,给定一张图片,目标检测系统要能够识别出图片的目标并给出其位置,由于图片中目标数是不定的,且要给出目标的精确位置,目标检测相比分类任务更复杂.目标检测的一个实际应用场景就是 ...

  7. iOS开发——NSString小结

    1.创建常量字符串. NSString *astring = @"This is a String!";   2.创建空字符串,给予赋值. NSString *astring = ...

  8. 端口扫描软件Nmap使用一(下载于安装)

    端口扫描软件Nmap使用一(下载于安装) Nmap的下载地址虽然很多,但是对于新手来说,尽量在官方网址下载,某些第三方下载网址很不人道,使用他们加速器的时候会绑定下载很多垃圾软件,会给我们造成很多不必 ...

  9. Python内存分配器(如何产生一个对象的过程)

    目录 内存分配器 Python分配器分层 第零层--通用的基础分配器 第一层--低级内存分配器 内存结构 arena pool new arena usable_arenas和unused_arena ...

  10. 给一个执行在windows 7和NAT下的VMWARE虚拟机分配固定IP

    虚拟机上装了个oracleserver,每次vmware重新启动或者resume时总要分配新的IP地址,这样就得改动windows下的client配置,所以须要想办法把IP地址固定住. DHCP服务在 ...