`
univasity
  • 浏览: 808871 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Android反编译方法的总结[转]

阅读更多

ps:对于软件开发人员来说,保护代码安全也是比较重要的因素之一,不过目前来说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代码如下:


  1. <?xml version= "1.0"  encoding= "utf-8" ?>  
  2. <LinearLayout  
  3.     xmlns:android="http://schemas.android.com/apk/res/android"   
  4.     android:orientation="1"   
  5.     android:layout_width="-1"   
  6.     android:layout_height="-1"   
  7.     >  
  8.     <WebView  
  9.         android:id="@7F050000"   
  10.         android:layout_width="-1"   
  11.         android:layout_height="-2"   
  12.         >  
  13.     </WebView>  
  14. </LinearLayout>  

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

  1. <?xml version= "1.0"  encoding= "utf-8" ?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
  3.     android:orientation="vertical"   
  4.     android:layout_width="fill_parent"   
  5.     android:layout_height="fill_parent"   
  6.     >  
  7. <WebView  
  8.     android:id="@+id/apk_web"   
  9.     android:layout_height="wrap_content"   
  10.     android:layout_width="fill_parent"   
  11.       
  12. />  
  13. </LinearLayout> 

2:通过dex2jar工具进行反编译。

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

 

 

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


 

------------------------------------------------------------------------------

我还找到一位老兄封装好的apk反编译工具,具体看这里:

http://morry.iteye.com/blog/776718

 

ps:但可能dex2jar的版本有问题,我使用该工具反编译后的jar无法用jd-gui打开,而在官网 下载最新的dex2jar则可以。

  • 大小: 26.9 KB
  • 大小: 34.7 KB
  • 大小: 41.9 KB
  • 大小: 42.4 KB
分享到:
评论

相关推荐

    Android反编译工具包(最完整的Android反编译工具包)

    总结起来,这个最完整的Android反编译工具包是开发者和安全研究员的宝贵资源,包含了一系列用于解包、反编译和分析APK文件的工具。通过熟练掌握这些工具,可以深入了解Android应用程序的内部机制,提高开发技能,...

    Android反编译工具包

    总结,Android反编译工具包是开发者和安全研究者的重要工具,它帮助我们理解和探索APK的内部结构。通过熟练掌握这些工具的使用,我们可以更好地学习、调试和改进Android应用。然而,反编译过程也伴随着挑战,包括...

    Android 反编译工具 APKDB

    总结来说,APKDB是一个强大的Android反编译工具,通过其简洁的界面和鼠标右键快捷操作,让开发者能快速便捷地对APK进行逆向工程。对于学习Android编程、调试应用或进行逆向分析的开发者来说,APKDB无疑是一个得力的...

    Android 反编译 回编译神器

    总结一下,Android反编译和回编译是开发者进行APK分析和修改的重要手段。"Android 反编译 回编译神器"如APKDB简化了这一过程,使得开发者可以更专注于代码的分析和修改,而不需要过多关注底层的编译技术。对于...

    android 反编译小工具

    在实际操作中,使用“Android反编译工具.exe”这样的程序时,只需将APK文件拖放到程序界面上,它就会自动完成解压和解析工作,使开发者能便捷地查看和分析APK的内部结构。这在调试、逆向工程、安全审计等方面都有其...

    Android反编译

    在Android开发领域,有时...总结来说,Android反编译是Android开发和安全研究的重要手段,通过合理的工具和技术,我们可以对APK进行深入分析。然而,这也需要开发者具备一定的技术背景,并时刻关注合法性和道德边界。

    Android反编译利器一步搞定

    总结来说,“Android反编译利器”是一款集反编译、解析、可视化于一体的工具,对于想要学习Android逆向工程的新手,或者是需要快速分析APK的开发者,都是一个不可多得的助手。它简化了复杂的过程,使开发者能够更...

    Android反编译示例包

    总结起来,"Android反编译示例包"提供了一个实际操作的平台,让开发者能够了解如何在不破坏原有应用的前提下,安全地新增页面和资源。通过不修改R类、不使用动态布局以及正确处理资源ID,开发者可以有效地进行逆向...

    Android反编译工具包 图形界面 apk 一键反编译

    总结起来,Android反编译工具包提供了一种便捷的方式去探索APK的内部结构,无论是为了学习、研究还是调试。"Androidfby"和"apk2java"这样的工具简化了这一过程,使反编译更加直观。然而,使用这些工具时必须遵守相应...

    一步Android反编译

    本篇文章将深入探讨“一步Android反编译”的概念、工具和步骤,旨在提供一个方便快捷的方法来反编译Android应用程序(APK)。 首先,理解反编译的基本概念。Android应用的主要组成部分是Dalvik Executable (DEX) ...

    超全Android反编译工具包(图形、命令行、拖拽)

    总结,Android反编译工具如jd-gui、apktool和apk2java提供了不同的操作方式,满足不同层次和需求的开发者。图形化界面适合快速查看,命令行工具更适合高级用户进行深度修改,而拖拽式工具则简化了反编译过程,让不...

    Android 反编译工具包(含 前人教学)

    总结来说,Android反编译是开发者获取应用内部信息的一种技术手段,但同时也需要注意尊重知识产权和遵循法律法规。通过使用如Apktool、dex2jar等工具,结合相关的教学资源,我们可以更深入地理解和学习Android应用的...

    Android反编译工具apktool

    总结来说,"Android反编译工具apktool"是一个强大的APK分析和修改工具,对于开发者来说,它提供了洞察APK内部结构的窗口,同时也是二次开发和逆向工程的重要辅助工具。正确理解和使用Apktool,能提升开发者的技能...

    超级好用的android反编译工具

    总结起来,“超级好用的android反编译工具”是一个方便快捷的解决方案,它整合了APK反编译流程,让用户能够快速获取APK的源代码视图。但同时,用户也应当意识到反编译的法律风险以及代码可读性的问题。在实际使用中...

    Android 反编译工具 dex2jar

    本文将详细介绍`dex2jar`及其在Android反编译流程中的作用。 ### 一、dex2jar简介 `dex2jar`是由Pang Wu开发的一款开源工具,主要用于将Android应用的`.dex`文件(包含了应用程序的字节码)转换为Java类库的`.jar`...

    android反编译原理解析

    ### Android反编译原理解析 #### 一、反编译流程概述 在开始解析之前,我们先了解Android反编译的基本流程。...通过本文的介绍,相信你已经掌握了Android反编译的基本原理及具体操作方法。希望这些信息对你有所帮助!

    Android反编译工具JEB -- 含MAC/Windows

    总结,JEB作为一款专业的Android反编译工具,为开发者提供了查看和理解APK源码的高效途径。通过其丰富的功能和易用的操作界面,无论是进行安全检测、性能优化还是学习借鉴,都能为开发者带来极大的便利。正确使用JEB...

Global site tag (gtag.js) - Google Analytics