Android反编译(二)

之反编译XML资源文件

[目录]

1、工具

2、反编译步骤

3、重新编译APK

4、实例

5、装X技巧

6、学习总结

1、工具

1).反编译工具 

apktool http://code.google.com/p/android-apktool/downloads/list

 

命令:

   apktool d [目标.apk] [目标文件夹]           ---------反编译(decode)
   apktool b [文件夹] [编译之后的名称.apk]---------编译(buid)
   apktool if framework-res.apk                  --------加载资源(install framework) 

2、反编译步骤

步骤1:将目标apk包,拷贝至apktool工具目录下
步骤2:CMD进入apktool文件夹,运行反编译命令
 CMD>apktool d Thinkdirve.apk  APK_SRC
(意思是将Thinkdirve.apk解包到当前APK_SRC目录下,APK_SRC文件夹不用创建,会自动生成)

3、重新编译APK

步骤1:将修改后资源文件后(APK_SRC)的文件夹重命名ThinkDrive_src
步骤2:CMD进入apktool文件夹, 运行打包命令

CMD>apktool b ThinkDrive_src ThinkDrive_src.apk

(注:重新编译后的APK需要重签名)

4、实例

>【例:反编译ThinkDrive.apk】

步骤1:将ThinkDrive.apk拷贝至apktool文件夹

步骤2:CMD进入apktool文件夹,运行反编译命令

结果:

>【例:重新编译ThinkDrive.apk】

步骤1:将修改后资源文件后(APK_SRC)的文件夹重命名ThinkDrive_src

步骤2:CMD进入apktool文件夹, 运行编译命令

结果:

5、装X技巧

写个批处理,双击运行,自动反编译当前目录下的所有apk,高端大气上档次,低调奢华有内涵啊~~~~

[apktool.bat] <--运行不了apktool时把这个下到apktool.jar所在目录
@echo off
set PATH=%CD%;%PATH%;
java -jar "%~dp0\apktool.jar" %1 %2 %3 %4 %5 %6 %7 %8 %9   

[反编译.bat]

@ECHO OFF
SETLOCAL ENABLEDELAYEDEXPANSION 
 REM 作者:Findyou
 REM 时间:2013.11.22
 REM SET C_PATH=%CD%
 FOR %%I IN (*.apk) DO (
     ECHO [反编译 %%I]
     ECHO --------------------------------
     REM 检查文件夹,如果已存在则先删除
     SET SRT=%%I
IF EXIST "!SRT:~0,-4!_src" (
ECHO [检查存在目标文件夹] 
ECHO [删除!SRT:~0,-4!_src]
RD /S /Q !SRT:~0,-4!_src
)
ECHO [反编译开始...]
ECHO -------------------------------
ECHO apktool d !SRT! !SRT:~0,-4!_src
ECHO -------------------------------
REM apktool d %C_PATH%\!SRT! %C_PATH%\!SRT:~0,-4!_src
CALL apktool.bat d !SRT! !SRT:~0,-4!_src
ECHO -------------------------------
ECHO [反编译完成]
ECHO.
  )
 PAUSE
 @ECHO ON

6、学习总结

1)、什么是反编译和编译
    反编译就是把apk解包成可修改的文件
    编译(此处单指反编译后的重新编译)就是把修改过的东西重新打包
2)、为什么要反编译?
    稍微懂点的,都知apk的文件可以直接用rar打开。但是如果直接用rar打开xml文件全都是乱码呢?

3)、什么时候需要反编译?

程序主要分2种: a).系统应用软件;b).第三方apk应用。

我们在美化或者汉化或者去广告之类的时候,主要做的动作有2种:

a).替换图片:如果只是替换图片,我们不需要反编译,替换相应的图片(注意名称和格式和分辨率一致),就可以了,这个时候只需要使用rar来做就好了。
b).修改xml文件:除去图片文件,apk应用里我们能折腾的就是xml文件了。如上面所说的,如果用rar打开xml文件,是乱码,所以这个时候我们就需要反编译了。
4)、什么是签名? 
       为了保证每个应用程序开发商合法ID,防止部分开放商可能通过使用相同的Package Name来混淆替换已经安装的程序,我们需要对我们发布的APK文件进行唯一签名,保证我们每次发布的版本的一致性(如自动更新不会因为版本不一致而无法安装)。我们看到的META-INF文件夹就是签名的文件夹。

5)、什么时候需要签名?

a).如果是系统apk应用。
   如果仅仅是替换图片,不需要反编译,也不需要重新签名,直接用rar替换就可以.
   如果进行了反编译,修改完xml文件之后,我们需要把他重新编译回去。编译好的应用不能直接放入手机内用,因为系统只认识他给的签名,而我们自己签名是不被认可的。
   处理方法:我们把之前从系统拿出来的原版apk起名为a.apk,把自己修改完毕,并且编译的好的应用起名为b.apk。用rar打开a.apk和b.apk,然后把b.apk里的resources.arsc文件直接拖到a.apk的压缩包里,然后把更换的图片以及修改过的XML文件也替换进去。 这个时候,我们做的相当于仅仅替换了一些资源,我们还是用a.apk的签名。替换完之后,就可以直接使用了。如果有的时候修改过smali文件夹,就需要把class.dex文件也copy过去。
b).如果是第三方apk应用
   第三方的apk应用,不管你修改了图片还是反编译了,都需要重新签名。方法是把META-INF里面的除了COM文件夹都删掉,就是删掉MF,SF,RSA这三个后缀名的文件然后使用工具签名。安装的时候要把原有的应用删掉再安装。

6)、签名工具

签名生成:keytool

重新签名:jarsigner

优化APK:zipalign

重签名,下篇有时间再写博分享。

转载请注明出处:Findyou

Android反编译(二)之反编译XML资源文件的更多相关文章

  1. (转载)Android xml资源文件中@、@android:type、@*、?、@+引用写法含义以及区别

    原帖地址:http://blog.csdn.net/zfrong/article/details/7332545 Android xml资源文件中@.@android:type.@*.?.@+引用写法 ...

  2. res文件夹及xml资源文件详解

    目录 一.values文件:存放字符串(strings).颜色(colors).尺寸(dimens).数组(arrays).样式(styles类似于CSS文件).类型等资源 二.drawable:存放 ...

  3. Android将Activity 打 jar包 (解决资源文件不能打包的问题)

    转载地址:http://blog.csdn.net/xiaanming/article/details/9257853 最近有一个需要,我们公司做了一个apk客户端,然后其他的公司可以根据自己的需要来 ...

  4. Android 开发手记二 C可执行程序编译实例(转帖)

    http://www.cnblogs.com/gaozehua/archive/2011/09/02/2164077.html

  5. Android xml资源文件中@、@android:type、@*、?、@+含义和区别

    一.@代表引用资源 1.引用自定义资源.格式:@[package:]type/name android:text="@string/hello" 2.引用系统资源.格式:@andr ...

  6. 【转】Android xml资源文件中@、@android:type、@*、?、@+含义和区别

    一.@代表引用资源 1.引用自定义资源.格式:@[package:]type/name android:text="@string/hello" 2.引用系统资源.格式:@andr ...

  7. idea中maven项目xml资源文件无法读取

    解决方法:编辑pom.xml文件 添加如下标签 <build> <resources> <resource> <directory>src/main/j ...

  8. 使用PULL方式解析XML资源文件下面的xml文件

    public class MainActivity extends Activity { private Button btn = null; private List<Map<Strin ...

  9. kettle 导入xml 资源文件

    Repository | ExploreRight click the root node of the repositorySelect Import objects from an XML fil ...

随机推荐

  1. UNET学习笔记2 - 高级API(HLAPI)

    高级API是在实时传输低级API基础上建立起来的,为多人游戏提供大量通用的组件.通过HLAPI开发者仅需少量的工作就可以搭建多人联网游戏. HLAPI 使用命名空间 UnityEngine.Netwo ...

  2. C#中使用OpenSSL的公钥加密/私钥解密

    在C#中进行公钥加密/私钥解密,需要用RSACryptoServiceProvider,但是它不支持由OpenSSL生成的公钥/私钥字符串. 比如这样的公钥/私钥对( 公私钥生成方法见 http:// ...

  3. 算法:poj1066 宝藏猎人问题。

    package practice; import java.util.Scanner; public class TreasureHunt { public static void main(Stri ...

  4. 源程序版本管理软件和项目管理软件,Github注册流程

    目前流行的源程序版本管理软件和项目管理软件:Microsoft TFS,Github,SVN,Coding 各自的优缺点: Microsoft TFS: 优点: tfs核心的,是对敏捷,msf,cmm ...

  5. 使用ruby过程中遇到安装gem失败的一些通用解决方案

    ruby语言升级还是比较勤快的.但是数量众多的版本使得程序库的兼容性成了大问题.有些gem表示明确不支持某个特定版本以前的ruby,而有些gem则与较高的版本不兼容.再加上gem本身也有版本,简直是乱 ...

  6. 记录自己在使用Bootstrap中的心得

    一.网格系统 在做CRM OP后台时,直接在前人的的一些页面上进行了修改和增加,发现一些东西增加字段后有问题,比如网格系统,怎么改样式都不对,最后自己没法发,做成了半响应式的了.今天重新看Bootst ...

  7. NodeJS系列~第四个小例子,NodeJs处理Get请求和Post请求

    返回目录 说在前 对于HTTP请求来说,我们通常使用的是Get和Post,除此之外还有put,delete等,而对于get来说,比较lightweight,只是对字符串的传输,它会被添加到URL地址里 ...

  8. 转 jsp中 session的简单用法

    Session对象:是用来分别保存每一个用户信息的对象,以便于跟踪用户的操作状态.Session的信息保存在服务端,Session的ID保存在客户机的Cookie中.事实上,在许多服务器上,如果浏览器 ...

  9. Atitit 代理CGLIB 动态代理 AspectJ静态代理区别

    Atitit 代理CGLIB 动态代理 AspectJ静态代理区别 1.1. AOP 代理主要分为静态代理和动态代理两大类,静态代理以 AspectJ 为代表:而动态代理则以 spring AOP 为 ...

  10. 一条Select语句丛生到死的处理过程

    以一条普通的“select * from table order by …”语句为例.图2-21中显示为该语句在数据库中各个组件之间的处理过程,各个步骤分别代表: (1)select语句通过网络传送给 ...