首页
社区
课程
招聘
[原创][原创]微信系列研究之-----资源文件保护的小把戏
发表于: 2015-7-11 00:19 29396

[原创][原创]微信系列研究之-----资源文件保护的小把戏

2015-7-11 00:19
29396

前言

微信对APK进行多维度的保护,包括我们以前提到的客户端到服务器验证签名,插件验证,文件变动检测,代码混淆,把核心功能放在SO中等。
其中比较有特色的是对资源文件的保护,防止被恶意分析和山寨。
目前在国内对资源文件进行保护的APK还比较少,大部分都只对代码和插件进行了保护,所以微信这个特色值得我们去破解一下。

现象

我们通过APKTOOL对微信的APK进行反编译时就会发现 APKTOOL 只生成了 assets,lib,res,smali目录(有些版本的APKTOOL还生成了UNKOWN目录)。
进入资源文件目录,我们还发现图片文件比较少。缺少大量的布局文件XML。

如果我们利用APKTOOL对微信反编译后再打包,会出现一大堆错误。
但如果我们直接把APK改名为ZIP,并解压后,会发现还有r目录。这其中必有蹊跷。

原理
由于APKTOOL反编译时只对RES目录下的 二进制XML进行反编译。
而对应RES下的二进制XML引用的其他目录下的二进制XML无法识别。
微信正是通过这个缺陷对APKTOOL进行了欺骗。

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <item type="layout" name="a3l">r/o/a3l.xml</item>
</resources>

破解方法:



ANDROID中activity查找资源文件的是
activity (根据ID查找)->R.java对应的资源标号-》资源ID查找的对应的资源路径-》找到文件的路径,读取相应的文件配置)。

1.从源码中分析,这里我们以weixin531.apk中的 com.tencent.mm.ui.setting.EditSignatureUI.java 为例

com.tencent.mm.ui.setting.EditSignatureUI.java

import com.tencent.mm.i;
import com.tencent.mm.k;

  protected final void DP()
  {
    oP(n.cgU);
    this.jLo = ((EditText)findViewById(i.content));
    this.hqI = ((TextView)findViewById(i.baa));
    String str = ap.ja((String)bg.qW().oQ().get(12291));
    this.jLo.setText(str);
    this.jLo.setSelection(this.jLo.getText().length());
    this.hqI.setText(v(this.jLo.getEditableText()));
    EditText localEditText = this.jLo;
    InputFilter[] arrayOfInputFilter = new InputFilter[1];
    arrayOfInputFilter[0] = new e(this);
    localEditText.setFilters(arrayOfInputFilter);
    this.jLo.addTextChangedListener(new f(this, (byte)0));
    a(new c(this));
    a(0, getString(n.bud), new d(this), cu.iMA);
    eB(false);
  }

  protected final int getLayoutId()
  {
    return k.bek;
  }

我们可以看到 

LayoutId 布局资源ID为 k.bek,
EditText jLo 控件对应的ID 为 i.content

从中我们知道对应的R.JAVA分别为 com.tencent.mm.k和 com.tencent.mm.i

通过com.tencent.mm.k.java 我们可以查到  
public static final int bek = 2130903326;
通过十六进制转化 (2130903326-> 0x7F03011E )我们可以知道 EditSignatureUI.java对应的布局文件的ID为 0x7F03011E

通过com.tencent.mm.k.java 我们可以查到  

 public static final int content = 2131165340;
通过十六进制转化 (2131165340-> 0x7F07009C )我们可以知道 EditText控件对应的布局文件的ID为 0x7F07009C。或者直接从com.tencent.mm.k.smali中查找,这样可以不用进行十六进制转化。

2.利用AAPT分析AP资源的表,得到相应的资源编号文件
aapt dump --values resources weixin531.apk > resources.txt

3.通过查表我们可以找到对应的layout.xml 为 r/t/h0.xml.

resource 0x7f03001e com.tencent.mm:layout/h0: t=0x03 d=0x0000028e (s=0x0008 r=0x00)
          (string8) "r/t/h0.xml"

4.利用AAPT查找到的内容对二进制XML进行反编译输出
aapt dump --values xml
tree weixin531.apk r/t/h0.xml > h0.xml.txt 
到这一步基本就得到我们想要的资源布局文件了。

5. 我们还可以利用AXMLPrinter2对单个二进制XML 进行反编译输出

java -jar AXMLPrinter2.jar h0.xml  >> ho.xml.txt

得到的结果如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="1"
        android:layout_width="-1"
        android:layout_height="-2"
        >
        <LinearLayout
                android:orientation="0"
                android:background="@7F02053B"
                android:layout_width="-1"
                android:layout_height="-2"
                android:layout_marginLeft="@7F0A0021"
                android:layout_marginTop="@7F0A0022"
                android:layout_marginRight="@7F0A0021"
                >
                <EditText
                        android:textColor="@7F090026"
                        android:textColorHint="@7F090037"
                        android:gravity="0x00000030"
                        android:id="@7F07009C"
                        android:background="@00000000"
                        android:layout_width="0.0dip"
                        android:layout_height="-2"
                        android:singleLine="false"
                        android:layout_weight="1.0"
                        style="@7F0D008D"
                        >
                </EditText>
                <TextView
                        android:textSize="@7F0A0016"
                        android:textColor="@7F090029"
                        android:layout_gravity="0x00000055"
                        android:id="@7F070380"
                        android:padding="@7F0A001D"
                        android:layout_width="-2"
                        android:layout_height="-2"
                        >
                </TextView>
        </LinearLayout>
        <LinearLayout
                android:gravity="0x00000001"
                android:layout_width="-1"
                android:layout_height="-2"
                android:layout_marginTop="@7F0A0023"
                >
                <TextView
                        android:textSize="@7F0A0015"
                        android:textColor="@7F090064"
                        android:layout_gravity="0x00000055"
                        android:id="@7F0703BA"
                        android:padding="@7F0A001D"
                        android:visibility="2"
                        android:layout_width="-2"
                        android:layout_height="-2"
                        android:text="@7F0C0797"
                        >
                </TextView>
        </LinearLayout>
</LinearLayout>

通过布局文件,我们可以看到 EDITTEXT 控件 编号为(android:id="@7F07009C")对应的风格了。

如果布局文件太多,我们还可以批量进行

for /f  "tokens=*" %%a in ('dir /s/b/a-d "*.xml"') do (echo.%%a 
@java -jar AXMLPrinter2.jar "%%a"  >>"%%na".txt) 
pause

由于AXMLPrinter2久未更新,AXMLPrinter2对ANDROID高版本的XML文件无法反编译,为此我们需要下载修改过BUG的AXMLPrinter2

资源分享 修正后的AXMLPrinter2
   http://download.csdn.net/detail/simbaba/8625893


[课程]Android-CTF解题方法汇总!

收藏
免费 3
支持
分享
最新回复 (21)
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
MARK下。
2015-7-11 01:27
0
雪    币: 8
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
3
资源文件保护
2015-7-11 08:31
0
雪    币: 100
活跃值: (471)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
很好很强大,顶起来
2015-7-11 11:35
0
雪    币: 32
活跃值: (34)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
5
加精贴,前排留名
2015-7-12 09:47
0
雪    币: 94
活跃值: (2197)
能力值: ( LV3,RANK:30 )
在线值:
发帖
回帖
粉丝
6
这个不错
2015-7-12 17:45
0
雪    币: 201
活跃值: (16)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
7
感谢楼主,mark一下
2015-7-12 17:48
0
雪    币: 76
活跃值: (206)
能力值: ( LV2,RANK:15 )
在线值:
发帖
回帖
粉丝
8
感谢LZ无私奉献 MARK下
2015-7-13 10:05
0
雪    币: 211
活跃值: (52)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
9
分析的不错。顶你
2015-7-15 09:05
0
雪    币: 1906
活跃值: (712)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
10
精品来了,持续更新,长久支持,赞
2015-7-15 09:24
0
雪    币: 55
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
11
马克..值得学习一下,感谢楼主
2015-7-15 13:45
0
雪    币: 347
活跃值: (975)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
12
学习!感谢楼主
2015-7-21 22:50
0
雪    币: 188
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
13
资源文件保护值得研究一下。
2015-7-23 15:12
0
雪    币: 27
活跃值: (11)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
14
感谢楼主的无私奉献
2015-7-27 23:12
0
雪    币: 128
活跃值: (13)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
15
好多牛人,感谢分享
2015-8-11 11:28
0
雪    币: 37
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
16
很好很强大  支持支持
2015-8-20 09:08
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
17
没看懂,功力还差得远
2016-2-15 18:07
0
雪    币: 199
活跃值: (306)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
18
大赞 mark
2016-2-19 10:53
0
雪    币: 218
活跃值: (17)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
19
能否加一下我的扣:49零8零1零零7
重金酬谢请教问题。
2016-3-1 23:58
0
雪    币: 20
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
20
MARK
2016-10-11 14:49
0
雪    币: 2
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
21
可以加下吗?扣403308000    必有重谢
2017-7-17 03:04
0
雪    币: 3
活跃值: (15)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
22
微信的资源保护应该用的是他们微信自己开源的AndResGuard资源混淆工具吧,主要是对资源名的混淆和资源的压缩
2017-7-17 11:46
0
游客
登录 | 注册 方可回帖
返回
//