`
MyEyeOfJava
  • 浏览: 1159182 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
7af2d6ca-4fe1-3e9a-be85-3f65f7120bd0
测试开发
浏览量:71399
533896eb-dd7b-3cde-b4d3-cc1ce02c1c14
晨记
浏览量:0
社区版块
存档分类
最新评论

[Android]转-Android 中的拿来主义(编译,反编译,AXMLPrinter2,smali,baksmali)!

阅读更多
原文地址

一、前言:

大家好,今天给大家分享一下Android中的拿来主 义,我们时常会碰到一个自己觉得很漂亮很帅气的应用(apk),所以我们会尝试用WinRAR等之类工具查看,而一般的应用程序打包后的目录通常是这样的 如下图:



当然res里的图片是可以拿来就用的(笔者的好多应用的图片都是从别人的apk里扣出来的),而诸如layout里的布局及权限文件 (AndroidManifest.xml)已经是一堆乱码了,完全看不懂,想看看别人是怎么布局的都不容易。还有源代码都被编译成了 classes.dex,完全看不出什么线索。基于以上的困惑,笔者给大家分享一下Android中的拿来主义。

二、所需工具(点击各自连接进入下载页面):

1.AXMLPrinter2.jar

2.baksmali.jar

3.smali.jar

三、准备工作

为了方便起见,作者把AXMLPrinter2.jar, 还有baksmali.jar,还有smali.jar(下下来为了方便重命名),放在Android SDK tools文件夹中如下图所示:



为了便于大家更容易程序比对,作者写了一个简单的应用(叫APKInstaller)目录结构如下图所示:



四、开始拿来主义

1.用 AXMLPrinter2.jar查看apk中的布局xml文件:

将ApkInstaller应用生成的ApkInstaller.apk(为了方便起见放到tools目录里)用WinRAR等 工具打开,将res/layout/main.xml解压出来(也还是放在tools目录里哦)

打开main.xml文件,内容如下(一堆天文):



这时候AXMLPrinter2.jar派上用场了,打开cmd终端,一直进入到tools目录下,输入如下命令:

java -jar AXMLPrinter2.jar main.xml > main.txt.  (如下图所示)



打开main.txt代码如下(是不是有个123了呵呵~):

[java] view plaincopy
<?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="-1"  
    >  
    <WebView  
        android:id="@7F050000"  
        android:layout_width="-1"  
        android:layout_height="-2"  
        >  
    </WebView>  
</LinearLayout>  


为了比对打开源程序中的main.xml代码如下(大家比对一下吧):

[java] view plaincopy
<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >  
<WebView  
    android:id="@+id/apk_web"  
    android:layout_height="wrap_content"  
    android:layout_width="fill_parent"  
      
/>  
</LinearLayout>  


2.用baksmali.jar反编译classes.dex:

将ApkInstaller.apk里的classes.dex解压到tools目录里,然后baksmali.jar就派上用场了,在cmd命令行里输入如下命令:

java -jar baksmali.jar -o classout/ classes.dex .(如下图所示:)



你将会发现在tools里多一个classout文件夹里面(我代码的包目录结构清晰可见呀),如下图所示:



从上面看出除了Android本身资源的类R开头的,我的源程序里只有一个ApkInstaller.java,完全吻合,真TMD的猥琐呵呵~

下面我们看一下ApkInstaller.smali内容是什么,如以下代码:

[java] view plaincopy
.class public Lcom/tutor/apkinstaller/ApkInstaller;  
.super Landroid/app/Activity;  
.source "ApkInstaller.java"  
# instance fields  
.field private apkWeb:Landroid/webkit/WebView;  
# direct methods  
.method public constructor <init>()V  
    .registers 1  
    .prologue  
    .line 8  
    invoke-direct {p0}, Landroid/app/Activity;-><init>()V  
    return-void  
.end method  
# virtual methods  
.method public onCreate(Landroid/os/Bundle;)V  
    .registers 5  
    .parameter "savedInstanceState"  
    .prologue  
    .line 13  
    invoke-super {p0, p1}, Landroid/app/Activity;->onCreate(Landroid/os/Bundle;)V  
    .line 14  
    const/high16 v2, 0x7f03  
    invoke-virtual {p0, v2}, Lcom/tutor/apkinstaller/ApkInstaller;->setContentView(I)V  
    .line 15  
    const/high16 v2, 0x7f05  
    invoke-virtual {p0, v2}, Lcom/tutor/apkinstaller/ApkInstaller;->findViewById(I)Landroid/view/View;  
    move-result-object v2  
    check-cast v2, Landroid/webkit/WebView;  
    iput-object v2, p0, Lcom/tutor/apkinstaller/ApkInstaller;->apkWeb:Landroid/webkit/WebView;  
    .line 16  
    iget-object v2, p0, Lcom/tutor/apkinstaller/ApkInstaller;->apkWeb:Landroid/webkit/WebView;  
    invoke-virtual {v2}, Landroid/webkit/WebView;->getSettings()Landroid/webkit/WebSettings;  
    move-result-object v1  
    .line 17  
    .local v1, webSettings:Landroid/webkit/WebSettings;  
    const/4 v2, 0x1  
    invoke-virtual {v1, v2}, Landroid/webkit/WebSettings;->setJavaScriptEnabled(Z)V  
    .line 19  
    const-string v0, "http://frankiewei.net/apk/demos/main/index.html#home"  
    .line 20  
    .local v0, apkUrl:Ljava/lang/String;  
    iget-object v2, p0, Lcom/tutor/apkinstaller/ApkInstaller;->apkWeb:Landroid/webkit/WebView;  
    invoke-virtual {v2, v0}, Landroid/webkit/WebView;->loadUrl(Ljava/lang/String;)V  
    .line 21  
    return-void  
.end method  

同样为了比对我们看一下ApkInstaller.java的源代码如下:

[java] view plaincopy
package com.tutor.apkinstaller;  
import android.app.Activity;  
import android.os.Bundle;  
import android.webkit.WebSettings;  
import android.webkit.WebView;  
public class ApkInstaller extends Activity {  
     
    private WebView apkWeb;  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
       apkWeb = (WebView)findViewById(R.id.apk_web);  
       WebSettings webSettings = apkWeb.getSettings();  
       webSettings.setJavaScriptEnabled(true);  
        
       String apkUrl = "http://frankiewei.net/apk/demos/main/index.html#home";  
       apkWeb.loadUrl(apkUrl);  
    }  
}  



我相信大家 已经能看出来门道来了吧,hoho~



3.用smali.jar编译classout成classes.dex:

我们上一步已经将classes.dex反编译成了.smali文件,好了,我们看看smali文件看够了,在偿试把它编译成classes.dex吧,

输入如下命令:java -jar smali.jar classout/ -o classes.dex. 如下图所示:





我们可以将新生成的classes.dex塞入ApkInstaller.apk里覆盖原来的classes.dex文件,这样我们的apk还是一样能用的哦~



Ok~今天就暂时写到这里,这片文章真是不容易呀,写了这么长时间,之间还出现过被来自武汉IP的人把这篇文章删除 过,我又重新写了一遍。希望大家多多进步!thx~
分享到:
评论

相关推荐

    Android反编译 AXMLPrinter2 baksmali smali dex2jar jd-gui

    1、用AXMLPrinter2.jar反编译xxx.xml文件 解压xxx.apk,选择main.xml(也可选择其它xml文件,不过xml文件都是乱码),复制到AXMLPrinter2.jar所在目录,通过cmd 进入到AXMLPrinter2.jar所在目录,使用如下命令,得到的...

    AXMLPrinter2、baksmali、smali、dex2jar

    1、用AXMLPrinter2.jar反编译xxx.xml文件 解压xxx.apk,选择main.xml(也可选择其它xml文件,不过xml文件都是乱码),复制到AXMLPrinter2.jar所在目录,通过cmd 进入到AXMLPrinter2.jar所在目录,使用如下命令,得到的...

    AXMLPrinter2.jar baksmali_and_smali-1.3.2

    AXMLPrinter2.jar 和 baksmali_and_smali-1.3.2 是两个在Android逆向工程领域中常用的工具,它们主要用于解析和反编译Android应用程序的资源和代码。了解这些工具可以帮助我们深入理解Android应用的工作原理,进行...

    Android反编译

    接下来,我们开始实践Android的“拿来主义”: 1. **使用AXMLPrinter2.jar查看布局XML文件**:打开终端,进入tools目录,然后运行`java -jar AXMLPrinter2.jar main.xml &gt; main.txt`。这将把XML文件转换为更易读的...

    android反编译工具

    总之,smali.jar、AXMLPrinter2.jar和baksmali.jar是Android反编译过程中的重要工具,它们分别负责Dalvik字节码的反编译、AXML资源的解析和反编译,为开发者提供了深入理解Android应用内部机制的途径。熟悉并掌握...

    android反编译2

    这篇关于“android反编译2”的文章主要讲解了如何逆向工程一个Android APK,以便查看和分析其组件和资源。以下是文章中涉及的关键知识点的详细说明: 1. **工具介绍**: - **JDK**:Java Development Kit,是开发...

    android的反编译软件

    这个压缩包包含了三个关键文件:smali.jar、baksmali-1.2.6.jar和AXMLPrinter2.jar,它们分别对应于Android反编译流程中的不同步骤。 首先,让我们了解APK文件的结构。APK是一个包含Android应用所有资源、代码、...

    Android反编译工具介绍与简单实用方法

    Android 反编译工具有很多,如 APKtool、dex2jar、baksmali、ddx 等,每种工具都有其特点和使用方法。 首先,使用 dex2jar 工具可以将 APK 文件中的 classes.dex 文件转换为 Jar 文件,然后使用 JD-GUI 或者 ...

    android 反编译

    2. 使用baksmali将.dex文件反编译成smali代码,这将生成一堆.smali文件,每个文件对应一个类。 3. 接下来,可以使用AXMLPrinter2.jar解析.axml文件,得到XML格式的布局描述。 4. 对于更深入的分析,可能还需要使用...

    Android学习笔记之反编译工具介绍及下载(An-Better工作室)参照.pdf

    AXMLPrinter2.jar是一个用于反编译Android应用程序资源XML文件的工具。将此工具放置在Android SDK的tools目录下,通过命令行进入该目录,然后运行`java -jar AXMLPrinter2.jar 文件名.xml &gt; 输出文本文件.txt`,...

    详解android应用程序的反编译汇编.pdf

    Android应用程序的反编译是一个复杂但实用的过程,对于开发者来说,这能帮助理解已存在的应用工作原理,学习他人代码,或者进行二次开发。本文将详细介绍如何反编译Android的APK文件,主要包括以下几个步骤和涉及的...

    APK反编译工具集

    4. 如果需要深入到Dalvik字节码级别,可以使用Baksmali将DEX文件反编译为Smali代码,并用Smali将其重新汇编回去。 需要注意的是,APK反编译涉及到软件版权和隐私问题,未经许可的反编译可能会触犯法律。因此,这些...

    android反编译

    2. **baksmali.jar**:用于将APK中的`.dex`文件反编译为`.smali`文件,这是一种类似于Java字节码的中间语言,便于阅读理解。 3. **smali.jar**:与baksmali相反,用于将`.smali`文件重新编译为`.dex`文件,主要用于...

    apk-tools apk反编译

    在Android开发领域,APK工具(apk-tools)和APK反编译技术是开发者和逆向工程师常用的工具,用于理解应用程序的工作原理、修改资源或去除不必要的功能,如广告。APK是Android应用的安装包,它包含了应用的代码、资源...

    apk反编译工具大全

    Baksmali用于将dex文件(Dalvik执行文件)反编译成Smali代码,而Smali则用于将Smali代码编译回dex文件。 5. **ddx1.26.jar**:DDX工具用于将dex文件转换为更易读的Java源代码,便于分析和理解Android应用的运行逻辑...

    最新整理android反编译工具

    因个人需要,特整理了一些常用android反编译工具。smali-1.2.6.jar、jd-gui.exe、dex2jar-0.0.7.9-SNAPSHOT.zip、baksmali.jar、AXMLPrinter2.jar。

    反编译Android的apk文件的六种方法.pdf

    ### 反编译Android的APK文件的六种方法 #### 概述 在学习Android编程的过程中,有时候需要对已发布的应用程序进行分析学习。然而,这些应用通常是以APK文件形式发布,用户无法直接访问其源代码。因此,掌握如何反...

    APK反编译&源码查看工具

    1. **dex2jar**:APK中的.dex文件是Dalvik虚拟机执行的字节码,而dex2jar工具可以将.dex文件转换为Java的.class文件,这是反编译的第一步。它使得我们可以用Java反编译器来处理这些.class文件。 2. **JD-GUI** 或 *...

    apk反编译工具

    APK反编译工具是Android应用开发者和安全研究人员常用的软件,用于查看、修改或分析APK文件的内容。APK文件是Android系统中应用程序的打包格式,包含了应用的代码、资源、配置等所有必要组成部分。本篇文章将深入...

    反解APK三剑客.rar

    2. **反编译DEX**:然后使用Baksmali将.dex文件反编译成Smali代码,使我们能够阅读和理解程序逻辑。 3. **解析AXML**:接着,用AXMLPrinter2解析.axml文件,将其转换为可读的XML格式,便于查看资源和配置信息。 4. *...

Global site tag (gtag.js) - Google Analytics