Android程序反编译

 
  • 很早之前看过牛人写的关于反编译apk的方法,太过于复杂,现在有简单的了,这里顺便提一下。

    准备工具:

    dex2jar

    jd-gui

    步骤:

    1,  下载上面提到两个小软件,网上到处都有。

    2,  apk后缀名改为压缩软件识别的后缀,例如zip

    3,  解压改后缀名后的软件包

    4,  dos界面进入准备好的工具dex2jar目录,运行dex2ja class.dex

    5,  将地步反编译好的jarjava反编译工具再反编译为classok了,要是apk在打包之前没有混淆的话,反编译的效果很多,包结构很清晰,目前市面上好的软件基本都可以反编译哦。

     

    源文档 <http://kuikui.javaeye.com/blog/730441>

     

     

    一、更改apk文件的后缀名,如:LianyunHelper3.0.11.apk改成LianyunHelper3.0.11.zip

    二、用zip解压缩LianyunHelper3.0.11.zip文件

    三、从解压缩的文件夹中取出classes.dex文件并放到dex2jar.bat所在目录

    四、运行cmd命令,进入dex2jar.bat所在的目录,输入dex2jar.bat classes.dex即可生成classes.dex.dex2jar.jar文件

    五、用jd-gui工具打开classes.dex.dex2jar.jar文件,即可看到源码

    六、将AndroidManifest.xml 文件放到AXMLPrinter2.jar所在目录,运行cmd命令,进入 AXMLPrinter2.jar所在目录,输入java -jar AXMLPrinter2.jar AndroidManifest.xml > AndroidManifest.txt。

     

    源文档 <http://www.pin5i.com/showtopic-android-decompile-apk-file.html>

     

     

    XML文件的反编译 

    在apk中的xml文件是经过压缩的,可以通过AXMLPrinter2工具解开,具体命令为: 

    java -jar AXMLPrinter2.jar AndroidManifest.xml  > AndroidManifest.txt

     

    源文档 <http://www.linuxidc.com/Linux/2010-08/28156.htm>

     

     

     

    开发总结:Android反编译方法的总结

     

    对于软件开发人员来说,保护代码安全也是比较重要的因素之一,不过目前来说Google Android平台选择了Java Dalvik VM的方式使其程序很容易破解和被修改,首先APK文件其实就是一个MIME为ZIP的压缩包,我们修改ZIP后缀名方式可以看到内部的文件结构,类似 Sun JavaMe的Jar压缩格式一样。

    不过比较区别的是Android上的二进制代码被编译成为Dex的字节码,所有的Java 文件最终会编译进该文件中去,作为托管代码既然虚拟机可以识别,那么我们就可以很轻松的反编译。所有的类调用、涉及到的方法都在里面体现到,至于逻辑的执 行可以通过实时调试的方法来查看,当然这需要借助一些我们自己编写的跟踪程序。Google最然在Android Market上设置了权限保护app-private文件夹的安全,但是最终我们使用修改定值的系统仍然可以获取到需要的文件。

     

    总结反编译主要的目的在于学习。利用反编译进行相关的汉化或修改,还是尽量不要吧,毕竟人家写个程序不容易啊!

     

    具体方法如下:

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

    AXMLPrinter2.jar

    dex2jar:

    查看Jar包的GUI工具

    二,开始行动

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

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

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

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

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

    打开main.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="-1"  

        >  

        <WebView  

            android:id="@7F050000"  

            android:layout_width="-1"  

            android:layout_height="-2"  

            >  

        </WebView>  

    </LinearLayout>  

     

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

    <?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:通过dex2jar工具进行反编译。

    把apk中的class.dex拷贝到dex2jar.bat所在目录。运行dex2jar.bat class.dex,将会在其文件夹下生成classes.dex.dex2jar.jar。

    3、可以将jar文件重新命名后拷贝到GUI文件夹下,运行JD-GUI工具(它是绿色无须安装的),打开上面的jar文件,即可看到源代码。

     

    源文档 <http://tech.it168.com/a2010/1011/1111/000001111963.shtml>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值