Android常用逆向工具+单机游戏破解
android开发环境搭建
我理解的学习路线是首先要掌握和了解常见的工具、搭建环境。然后就是缓慢的积累特征,通过长期的练习使自己进步,通过android逆向课程的学习。常用的工具如下:
android SDK工具包
(1)adb.exe:android debug bridge 安卓调试桥连接手机、模拟器。
D:\AndroidTools\Android_SDK\platform-tools
(2)monitor.exe:安卓设备监视器
D:\AndroidTools\Android_SDK\tools\monitor.bat
adb.exe 用于调试,monitor.exe用于监视
android adb shell命令约等价于linux shell命令
android集成开发的开发环境
(1)Android Studio
(2)IntelliJ IDEA
Android模拟器
(1)原生的模拟器
(2)BlueStacks[蓝叠]
(3)夜神
(4)海马玩
Android逆向工具
(0)集成类工具:jeb、apkkiller
(1)反编译工具:
baksmali.jar:将dex文件反汇编成smali代码
smali.jar:将smali代码汇编生成dex文件(android的可执行文件)
apktool.jar:基于smali、basksmali工具开发的,可以反编译apk文件成smali,也可以将smali文件回编译成apk文件,
(2)清单文件解密工具:
AXMLPrinter2.jar:清单解密工具,反编译apk中的xml文件
APKParse.jar:套用了Apktool中解析xml文件的源码。
APK15PBParse.jar:APKParse.jar修改而成,修复了原有工具的bug。
(3)APK签名工具:
signapk.jar:使用apktool生成的apk文件,是不能直接安装到模拟器或是手机中的,因为没有签名就会报错。
(4)dex转jar工具
dex2jar:将dex文件转化为java jar包,因为转成jar包之后,方便使用JD-GUI工具反编译成java源码。
(5)java源码反编译工具
JD-GUI:使用JD-GUI打开jar包,可以看到反编译的源码。

游戏破解思路
(1)找寻支付成功的信息,获取支付相关的函数。
(2)将支付成功的smali指令注入到支付失败的函数中。
操作步骤
(1)打开monitor,点击游戏中的购买按钮,抓取到支付的字符串。

(2)在apkkiller转换编码为unicode编码

(3)在apkkiller搜索字符串,然后使用自带的JD-GUI工具查看源码。

(4)在源码中定位到支付相关的函数。payCancel、payFailed、paySuccess

(5)到apkkiller中查找与支付相关函数相关的smali文件。然后smali指令中传参的常量值记录下来。

(6)在函数窗口处查找购买失败的函数(payFailed)、购买成功的函数(paySuccess)的函数传参值,将两者对比。

(7)对比出来传参值的区别后将购买成功(paySuccess)的函数传参值和购买失败(payFailed)的函数传参值相互替换。

(8)将修改后的值Ctrl+s保存后再编译一遍,得到编译后的APK放到模拟器中运行就可以达到破解的效果了。

(9)运行效果

Android常用逆向工具+单机游戏破解的更多相关文章
- Android 常用开发工具以及Mac常用软件
		Android 常用的开发工具记录.其中包括AndroidStudio(IDEA)插件.Mac 上好用的软件以及国内知名Android开发者博客等. Android Studio 插件 codota ... 
- Android常用的工具类
		主要介绍总结的Android开发中常用的工具类,大部分同样适用于Java.目前包括HttpUtils.DownloadManagerPro.ShellUtils.PackageUtils. Prefe ... 
- Android常用的工具类(转)
		主要介绍总结的Android开发中常用的工具类,大部分同样适用于Java.目前包括HttpUtils.DownloadManagerPro.ShellUtils.PackageUtils.Prefer ... 
- 2013最新Android常用的工具类整理
		主要介绍总结的Android开发中常用的工具类,大部分同样适用于Java. 目前包括HttpUtils.DownloadManagerPro.ShellUtils.PackageUtils. Pref ... 
- Android常用正则工具类
		此类提供日常开发中常用的正则验证函数,比如:邮箱.手机号.电话号码.身份证号码.日期.数字.小数.URL.IP地址等.使用Pattern对象的matches方法进行整个字符匹配,调用该方法相当于: ... 
- Android常用开发工具的用法
		1.在命令行创建.删除和浏览AVD 在命令行下管理AVD需要借助于android命令(位于Android SDK安装目录的tools子目录下),如果直接执行android子命令将会启动Android ... 
- Android常用的工具类SharedPreferences封装类SPUtils
		package com.zhy.utils; import java.lang.reflect.InvocationTargetException; import java.lang.reflect. ... 
- Android自动化测试探索(二)常用自动化工具
		Android常用自动化工具 ADB - 是Google提供的为Android编写UI测试用例的自动化工具, Android开发/测试人员不可替代的强大工具 uiautomator - 是Google ... 
- Unity 4.2.0 官方最新破解版(Unity3D 最新破解版,3D游戏开发工具和游戏引擎套件)
		Unity是一款跨平台的游戏开发工具,从一开始就被设计成易于使用的产品.作为一个完全集成的专业级应用,Unity还包含了价值数百万美元的功能强大的游戏引擎.Unity作为一个游戏开发工具,它的设计主旨 ... 
随机推荐
- day24 异常处理
			程序一旦发生错误,就从错误的位置停下不在执行后面的内容一般可能预估但是无法处理的问题可以用异常处理进行操作异常处理后会继续执行后面的代码 try: # 写在try中的语句是一定执行的 ret = in ... 
- 06 Zabbix分布式监控和主被动模式
			06 Zabbix分布式监控和主被动模式 zabbix proxy设置 使用zabbix代理的好处 监控拥有不可靠的远程区域 当监控项目数以万计的时候使用代理分担zabbix-proxy压力 简化分布 ... 
- Zabbix 添加对交换机端口流量超出阈值的监控
			点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 22 Zabbix 添加对交换机端口流量超出阈值的监控 本文主要讲解利用zabbix 添加对交换机 ... 
- cf379F New Year Tree (树的直径+倍增lca)
			可以证明,如果合并两棵树,新的直径的端点一定是原来两树中直径的端点 可以把新加两个点的操作看成是把两个只有一个点的树合并到原来的树上,然后用其中的一个点去和原来树上的直径两端点更新直径就可以了 #in ... 
- 全面解析Java类加载器
			深入理解和探究Java类加载机制---- 1.java.lang.ClassLoader类介绍 java.lang.ClassLoader类的基本职责就是根据一个指定的类的名称,找到或者生成其对应的字 ... 
- 洛谷 P1417烹调方案
			题目大意: 一共有n件食材,每件食材有三个属性,ai,bi和ci,如果在t时刻完成第i样食材则得到ai-t*bi的美味指数,用第i件食材做饭要花去ci的时间. 求最大美味指数之和. 分析: 显然的0/ ... 
- 快速幂&快速乘法
			尽管快速幂与快速乘法好像扯不上什么关系,但是东西不是很多,就一起整理到这里吧 快速幂思想就是将ax看作x个a相乘,用now记录当前答案,然后将指数每次除以2,然后将当前答案平方,如果x的2进制最后一位 ... 
- 拦截器的使用,配置手机浏览器访问的h5页面
			package com.thinkgem.jeesite.modules.sys.interceptor; import javax.servlet.http.HttpServletRequest; ... 
- POJ1742Coins(多重背包)
			Coins Time Limit: 3000MS Memory Limit: 30000K Total Submissions: 32309 Accepted: 10986 Descripti ... 
- [python网络编程]使用scapy修改源IP发送请求
			Python爬虫视频教程零基础小白到scrapy爬虫高手-轻松入门 https://item.taobao.com/item.htm?spm=a1z38n.10677092.0.0.482434a6E ... 
