吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 37756|回复: 24
收起左侧

[Android 原创] 记一次resources.arsc文件hex修改原理分析

[复制链接]
pwelyn 发表于 2015-8-31 10:43
需要用到的工具
aapt
ShakaApktool或apktool
Hex编辑器
文本编辑器
作者:越狱(pwelyn)
样本就不提供了,自己随便找个apk联手吧

感谢@随意 提供样本,本人比较菜,高手请忽略我在说什么,我只是把我的方法分享一下。

0x1 前奏
由于resources.arsc被重新hex来使ShakaApktool或apktool直接异常退出,我猜想的是利用apktool代码的bug来实现这个原理,其实aapt可以正常dump,下面就介绍一下如何实现,然后如何解决。

0x2 发现问题
先看看经过hex之后resources.arsc的apk文件反编译情况
apktool报错信息
[JavaScript] 纯文本查看 复制代码
I: Loading resource table...
Exception in thread "main" java.lang.NullPointerException
        at brut.androlib.res.data.value.ResValueFactory.factory(ResValueFactory.java:70)
        at brut.androlib.res.decoder.ARSCDecoder.readValue(ARSCDecoder.java:259)
        at brut.androlib.res.decoder.ARSCDecoder.readEntry(ARSCDecoder.java:203)
        at brut.androlib.res.decoder.ARSCDecoder.readConfig(ARSCDecoder.java:191)
        at brut.androlib.res.decoder.ARSCDecoder.readType(ARSCDecoder.java:159)
        at brut.androlib.res.decoder.ARSCDecoder.readPackage(ARSCDecoder.java:116)
        at brut.androlib.res.decoder.ARSCDecoder.readTable(ARSCDecoder.java:78)
        at brut.androlib.res.decoder.ARSCDecoder.decode(ARSCDecoder.java:47)
        at brut.androlib.res.AndrolibResources.getResPackagesFromApk(AndrolibResources.java:538)
        at brut.androlib.res.AndrolibResources.loadMainPkg(AndrolibResources.java:63)
        at brut.androlib.res.AndrolibResources.getResTable(AndrolibResources.java:55)
        at brut.androlib.Androlib.getResTable(Androlib.java:64)
        at brut.androlib.ApkDecoder.setTargetSdkVersion(ApkDecoder.java:209)
        at brut.androlib.ApkDecoder.decode(ApkDecoder.java:92)
        at brut.apktool.Main.cmdDecode(Main.java:165)
        at brut.apktool.Main.main(Main.java:81)


ShakaApktool报错信息
[JavaScript] 纯文本查看 复制代码
I: 常规资源列表...
I: 反编译资源文件...
I: 反编译 values */* XMLs...
Exception in thread "main" java.lang.NullPointerException
        at b.a.d.d.b.c(Unknown Source)
        at b.a.d.a.a.v.h(Unknown Source)
        at b.a.d.a.a.u.a(Unknown Source)
        at b.a.d.a.a(Unknown Source)
        at b.a.d.a.c(Unknown Source)
        at b.a.a.b(Unknown Source)
        at b.a.E.a(Unknown Source)
        at b.b.a.a(Unknown Source)
        at b.b.a.a(Unknown Source)
        at com.rover12421.shaka.cli.Main.main(Unknown Source)


报错信息都是Exception in thread "main" java.lang.NullPointerException
这个应该很好理解空指针异常,为什么会出现这种情况呢,直接进行ShakaApktool或apktool源码调试来查找问题(怎么调试这里就不说了)
通过调试可以发现string反编译到最后直接就抛出了异常,那么知道具体问题出在哪里,那么我们就接着往下走吧

0x3 问题分析
现在aapt就可以上场了,我用的aapt版本是v0.2-2166767
使用命令(aapt我设了变量,所以我可以直接运行)
aapt  l -v -a test.apk > log

//将信息打印到log文件,l命令是干嘛用的,自己去学习aapt命令吧,这里不做说明
打开log文件,开头显示如下图:
图片 1.png

信息量比较大这里就不全部截图了,然后我们搜索string,然后直接定位到最后一个string位置,因为前面调试的时候,是在最后才抛出异常的。
然后截图多几行有个对比
图片 2.png

resource 0x05040219这个就是资源id,d=0x05860586 这个就是罪魁祸首让反编译抛出异常的地方,为什么这么说如果研究过arsc文件就知道了,或者我们直接对比上面几行代码也可以发现,为什么其他都是0x0000而这个却不是

0x4 文件修改
下面直接召唤出hex编辑器(我使用UltraEdit,你们随意按照自己习惯)
用压缩工具打开apk把resources.arsc提取出来,用hex工具打开resources.arsc
直接搜索86 05 86 05(为什么这样,因为十六进制搜索需要反过来,所以不是05860586而是86058605)
图片 3.png
图片 4.png
直接定位到了,然后直接修改86058605为86050000,改完之后保存,然后替换到apk里面进行测试。
看最后反编译结果:
图片 5.png
0x5 功能实现

说了怎么去除这个,那么自己怎么实现这个功能呢,方法一样按照0x3 问题分析步骤来,你想hex哪个string字段,自己决定,我只是提供一下方法
resource 0x05040219 com.test:string/test_name: t=0x03 d=0x00000586 (s=0x0008 r=0x00) (PUBLIC)
有的d参数可能全部是0x00000000,那么这时候就要结合t和s参数后面的值来进行搜索了,如何搜索,搜索到怎么修改就参考上面说的方法吧,最后祝大伙折腾愉快,ShakaApktool应该会很快修复这个bug了

Apktool|ShakaApktool 简体中文汉化版|APK反编译工具(更新)
http://www.52pojie.cn/thread-347591-1-1.html




免费评分

参与人数 7热心值 +7 收起 理由
roxiel + 1 我很赞同!
iamernie8199 + 1 我很赞同!
powerjiang + 1 我很赞同!
cr7890 + 1 谢谢@Thanks!
evido + 1 谢谢@Thanks!
yuluo5566 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩.
Hmily + 1 感谢发布原创作品,吾爱破解论坛因你更精彩.

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

wangp-3366 发表于 2015-8-31 14:18
不为别的,就是为你增加人气,看见技术贴就兴奋
alsk 发表于 2015-8-31 20:17
290250511 发表于 2015-8-31 23:30 来自手机
AZ1036 发表于 2015-8-31 23:45
支持原创,支持技术帖
fengyr 发表于 2015-9-1 09:09
越狱兄的东西支持一下。
275475437 发表于 2015-9-1 09:34
楼主转hex一般用什么软件啊,在学校时就知道keil
小豆芽 发表于 2015-9-1 23:17
板凳,学习一下,很详细!
caoxin 发表于 2015-9-2 09:32
很好很强大
caoxin 发表于 2015-9-2 19:59
强大的楼主
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-9 18:08

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表