反编译从零到一

本篇文章已授权微信公众号 guolin_blog (郭霖)独家发布

一、介绍

反编译与防反编译的0到1系列第一篇。该篇目的是让读者了解反编译的基本过程,可以完全没有基础,也不用了解smali语法。文章里面demo提供所有 需要使用的apk以及相应的修改代码。只需傻瓜式的模仿就能够学会。

反编译与防反编译的0到1系列主要用于增加反编译技术栈,避免一些低级的错误让软件被有心者破解。因此后续还会有smali语法的介绍和smali的修改。 在.so文件中添加签名验证。

项目地址

二、工具

1、工具说明:工具存放在tools文件夹下,这里仅提供Mac版,其他版本可以根据网址下载
1.1、ApkTool
1.1.1、下载地址:https://ibotpeaches.github.io/Apktool/
1.1.2、集成:appt、apktool、apktool.jar,这三个文件拷贝到/usr/local/bin,升级的时候只需替换jar包
1.1.3、功能:
1.1.3.1、获取apk资源文件、AndroidManifest.xml文件、smali文件 apktool d xxx/xxx/crack.apk(生成文件在命令当前位置)
1.1.3.2、 重新打包 apktool b xxx/xxx/crack -o new_crack.apk
1.1.4、可能存在问题:

Exception in thread "main" brut.androlib.AndrolibException: Could not decode arsc file
at brut.androlib.res.decoder.ARSCDecoder.decode(ARSCDecoder.java:56)
at brut.androlib.res.AndrolibResources.getResPackagesFromApk(AndrolibResources.java:491)
at brut.androlib.res.AndrolibResources.loadMainPkg(AndrolibResources.java:74)
at brut.androlib.res.AndrolibResources.getResTable(AndrolibResources.java:66)
at brut.androlib.Androlib.getResTable(Androlib.java:50)
at brut.androlib.ApkDecoder.getResTable(ApkDecoder.java:189)
at brut.androlib.ApkDecoder.decode(ApkDecoder.java:114)
at brut.apktool.Main.cmdDecode(Main.java:146)
at brut.apktool.Main.main(Main.java:77) 
 解决方案:https://ibotpeaches.github.io/Apktool/ 下载最新jar包替换即可。

1.2、DexToJar
1.2.1、下载地址:https://sourceforge.net/projects/dex2jar/
1.2.2、功能:dex转jar
1.2.3、使用 mac: 将d2j-dex2jar.sh 托人命令行 将反编译apk拖入命令行

   /Users/xxx/Desktop/xxx/xxx/d2j-dex2jar.sh /Users/xxx/Desktop/xxx/crack.apk

1.3、JD-GUId
1.3.1、下载地址:http://jd.benow.ca/
1.3.2、功能: 读取jar文件
1.4、界面工具
1.4.1、下载地址:https://github.com/Jermic/Android-Crack-Tool

2、反编译思路
2.1、dexToJar 获取jar包
2.2、使用JD-GUI分析代码,定位位置
2.3、修改变量的值,或方法返回后重置返回值
2.4、重新打包,签名,安装

3、如何加大破解难度
3.1、加固
3.2、混淆
3.3、尽量别在代码中直接写中文,这样相当于完全暴露意图,尽量放在String.xml文件中。
3.4、在.so文件中验证签名

三、第一个demo:

1、功能:修改打印工具类,实现输出打印日志
2、影响:日志完全暴露。
3、建议:敏感性的日志尽量使用完就删除,一旦工具类被修改,日志也会完全暴露
4、具体复现
4.1、使用该demo


761425-8e674f2504e6bad2.png
761425-9e3b76c0aaf352bc.png
761425-596eb1c2e1df9bcf.png

这里简单的写了一个日志工具类,很可能和大家使用的不一样,但大多数日志都有一个开关逻辑。用这个开关去控制所有日志是否打印。
4.2、使用DexToJar 获取jar包(参照工具中获取jar的方法),然后分析


761425-9511a3c379b7d417.png
761425-e0840535eb03d662.png

这里的中文可以说为定位文件起来不小作用,我们只用去找a类中的a方法
4.3、使用ApkTool反编译apk(参照工具中的方法),然后修改


761425-aa885b1970bba28f.png

Log.d 能很轻松的定位修改位置。
if-eqz v0, :cond_0 #这句话的含义如果v0==0执行cond_0分支,执行cond_0分支就方法就结束了所以把v0值修改即可

761425-fb39cb1a8de41fda.png

“#“ 代表注释返回值赋值给v0 注释掉,重新给v0赋值
4.4、重新打包(参考工具)
4.5、签名(签名工具在assets中,key也准备好了,密钥就在项目里,自己找吧
4.6、安装打印


761425-5b4533e5a2a2e552.png

如果日志是这样的,那恭喜你,你成功了。

四、第二个demo:插入一个开始页

1.影响:app 可能被插入广告
2.建议:进行签名校验
3.步骤:
3.1、生成demo_two.apk和demo_two_2.apk

761425-e62e4495eadb412c.png

运行得到demo_two.apk,将assets的demo_two文件已经写好Activity和布局文件,添加到相应位置运行得到demo_two_2.apk 也可以直接使用文件夹中两个apk
3.2、反编译demo_two.apk
命令:apktool d demo_two.apk(文件真实路径)
3.3、反编译demo_two_2.apk
命令:apktool d demo_two_2.apk(文件真实路径)
3.4、合并smali文件
761425-705622101fbaece7.png

demo_two_2.apk反编译smali文件夹中的a.smali(TimerTask的匿名内部类产品)和InsertActivity.smali拷贝到demo_two.apk反编译的文件中。
3.5、修改AndroidManifest.xml文件
761425-d04cf8e54e761555.png

去掉默认的启动标志,添加新的启动Activity
3.6、修改资源id
761425-12650b8a22fe87a3.png

布局文件id可能在public.xml(res/values中)也有可能在R$layout.smali文件中(smail文件夹下)有可能是不同编译器版本造成的,
不在本篇讨论范围。layout id 最大的是0x7f04002e,在它的基础上加1即可(注意采用的是16进制)
761425-5242a42de42d54cc.png

过程中有可能遇到上面的错误,上面原因很明显id重复,说明新加的id不对。
3.7、修改smail文件的id
761425-1ce01e073dc13cec.png

找到setContentView()可以快速定位,将id替换成步骤3.6中添加的id
3.8、重新打包
命令:apktool b demo_two(文件真实路径) -o demo_two_new.apk -
3.9、签名安装
如果先显示“这是一个注入的页面”恭喜你成功了。如果没见到这个页面可以反编译demo_two_crack.apk查看一下原因

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值