龙马谷

 找回密码
 立即注册

QQ登录

只需一步,快速开始

龙马谷VIP会员办理客服QQ:82926983(如果临时会话没有收到回复,请先加QQ好友再发。)
1 [已完结] GG修改器新手入门与实战教程 31课 2 [已完结] GG修改器美化修改教程 6课 3 [已完结] GG修改器Lua脚本新手入门教程 12课
4 [已完结] 触动精灵脚本新手入门必学教程 22课 5 [已完结] 手游自动化脚本入门实战教程 9课 6 [已完结] C++射击游戏方框骨骼透视与自瞄教程 27课
7 [已完结] C++零基础UE4逆向开发FPS透视自瞄教程 29课 8 [已完结] C++零基础大漠模拟器手游自动化辅助教程 22课 9 [已完结] C++零基础开发DXF内存脚本辅助教程 32课
以下是天马阁VIP教程,本站与天马阁合作,赞助VIP可以获得天马阁对应VIP会员,名额有限! 点击进入天马阁论坛
1 [已完结] x64CE与x64dbg入门基础教程 7课 2 [已完结] x64汇编语言基础教程 16课 3 [已完结] x64辅助入门基础教程 9课
4 [已完结] C++x64内存辅助实战技术教程 149课 5 [已完结] C++x64内存检测与过检测技术教程 10课 6 [已完结] C+x64二叉树分析遍历与LUA自动登陆教程 19课
7 [已完结] C++BT功能原理与x64实战教程 29课 8 [已完结] C+FPS框透视与自瞄x64实现原理及防护思路
查看: 7402|回复: 0

Android APK反编译就这么简单 详细解释

[复制链接]

13

主题

2

回帖

20

积分

编程入门

Rank: 1

龙马币
54

学习Android开发过程,你会向别人学习如何应用软件的开发,那些漂亮的动画和复杂的布局可能让你爱不释手,作为开发者。你可能真的想知道的是如何实现的界面效果。然后。您将能够更改应用程序APK反编译查看。以下是我參考了一些文章后简单的教程具体解释。

(注:反编译不是让各位开发人员去对一个应用破解搞重装什么的,主要目的是为了促进开发人员学习。借鉴好的代码。提升自我开发水平。)


使用工具:
apktool
dex2jar
jd-gui
Android反编译整合工具包


工具介绍:
apktool  
作用:资源文件获取,能够提取出图片文件和布局文件进行使用查看

dex2jar
作用:将apk反编译成java源代码(classes.dex转化成jar文件)

jd-gui
作用:查看APK中classes.dex转化成出的jar文件,即源代码文件



反编译流程:

一、apk反编译得到程序的源码、图片、XML配置、语言资源等文件

下载上述工具中的apktool,解压得到3个文件:aapt.exe,apktool.bat。apktool.jar 。将须要反编译的APK文件放到该文件夹下,

打开命令行界面(执行-CMD) ,定位到apktool目录。输入下面命令:apktool.bat d -f  test.apk  test   

(命令中test.apk指的是要反编译的APK文件全名,test为反编译后资源文件存放的文件夹名称,即为:apktool.bat   d  -f    [apk文件 ]   [输出目录])

说明获取成功,之后发如今目录下多了个test文件。点击便能够查看该应用的全部资源文件了。

假设你想将反编译完的文件又一次打包成apk,那你能够:输入apktool.bat   b    test(你编译出来目录)便可。

之后在之前的test文件下便能够发现多了2个目录:

build

dist(里面存放着打包出来的APK文件)



二、Apk反编译得到Java源码

下载上述工具中的dex2jar和jd-gui ,解压

将要反编译的APK后缀名改为.rar或则 .zip,并解压,得到当中的额classes.dex文件(它就是java文件编译再通过dx工具打包而成的)。

将获取到的classes.dex放到之前解压出来的工具dex2jar-0.0.9.15 目录内,

在命令行下定位到dex2jar.bat所在文件夹,输入dex2jar.bat   classes.dex。效果例如以下:

在改文件夹下会生成一个classes_dex2jar.jar的文件,然后打开工具jd-gui文件夹里的jd-gui.exe,之后用该工具打开之前生成的classes_dex2jar.jar文件,便能够看到源代码了。



三、 图形化反编译apk

上述步骤一、二讲述了命令行反编译apk。如今提供一种图形化反编译工具:Androidfby

首先。下载上述反编译工具包,打开Androidfby文件夹。双击Android反编译工具.exe,就能够浏览打开要反编译的apk

通过反编译,你能够获知该应用用到了什么第3方的库文件。它的代码是怎样编写的等等。

然而。假设该APK进行了混淆处理,那么你看到的类文件名以及里面的方法名称都会以a,b,c....之类的样式命名,所以你能够想找到你所想得知的界面代码可能会十分费劲,

找到了代码可能看起来也会非常费劲,但是一个大体的思路会获得,有了这个思路,你就能够自己去尝试了。

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

龙马谷| C/C++辅助教程| 安卓逆向安全| 论坛导航| 免责申明|Archiver|
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表龙马谷立场!
任何人不得以任何方式翻录、盗版或出售本站视频,一经发现我们将追究其相关责任!
我们一直在努力成为最好的编程论坛!
Copyright© 2018-2021 All Right Reserved.
在线客服
快速回复 返回顶部 返回列表