反编译APK

反编译APK(Windows系统)

1.使用工具及其下载

(1)apktool
作用:资源文件获取工具,使用完的文件可以直接查看布局图片等资源文件,直接源格式显示,很好辨认。

下载地址: https://ibotpeaches.github.io/Apktool/install/ 要下载的是jar包,当我们使用一个工具的时候,不像从github看代码,下载全部的,要下工具的使用部分,这里点击Current version:2.3.4,就能下载,然后按照下面的提示一步步安装.
在这里插入图片描述
步骤大致就是
i.首先点击current version 要下载的是如上这样的,然后改名字为apktool.jar 或者直接从这里找到最新版本下载 https://bitbucket.org/iBotPeaches/apktool/downloads/
在这里插入图片描述
然后下载apktool.bat,点击上上张图片的这个蓝色位置
在这里插入图片描述
就能看到页面是一个在这里
https://raw.githubusercontent.com/iBotPeaches/Apktool/master/scripts/windows/apktool.bat
点击电脑上快捷键保存Ctrl+S,先随便存到一个路径下,后面还要改路径,同时后缀也要改,可以看到,我电脑默认的是txt,要删除,直接后缀是.bat。
在这里插入图片描述

ii.把apktool.jar和apktool.bat都移动到Windows路径中,一般都是C:/Windows 往里放的时候可能会被拒绝,再重试一次就好了。或者不拖动到这个目录下,在环境变量下的系统变量 path配置这两个的路径就行了
最后变成这样
在这里插入图片描述
然后在cmd命令行执行apktool命令,如果是这样的证明成功了
在这里插入图片描述
(2)dex2jar

作用:将apk反编译成java源码(classes.dex转化成jar文件)
下载地址在这里 https://github.com/pxb1988/dex2jar/releases
选择一个最新的版本安装即可,下载zip文件
在这里插入图片描述
然后解压缩,最后是这样的
在这里插入图片描述

(3)jd-gui

作用:查看APK中classes.dex转化成出的jar文件,即源码文件。这时的已经是处理过的,名称啥的变化了。
下载地址 https://github.com/java-decompiler/jd-gui/releases
下载最新版本
在这里插入图片描述
同样地,解压缩,变成这样
在这里插入图片描述

2.反编译过程

这里我选择我之前的一个小demo,我打了一个release包,后续操作对其进行处理
在这里插入图片描述
(1)首先使用apktool 工具将源apk转化一波。首先我们要知道apk是什么,其实她只是一个包含Resources和java代码的Zip,如果我们直接用解压文件的方式进行解压,会出现乱码,为了解决这个问题,apktool出现了。
使用方法就是:在命令行里敲如下命令
apktool d D:\testxml\app\build\outputs\apk\release\app-release-unsigned.apk(要反编译的apk文件,要在电脑上的完整路径名)
o new(要输出到的一个新文件夹的位置)
在这里插入图片描述
然后我们打开new文件夹
在这里插入图片描述
res里面的可以直接查看,源码格式,smail就是我们的业务代码,还不能查看。
(2)继续用dex2jar转化一波,这时就变成
命令 C:\Users\tingyu\dex2jar-2.0\d2j-dex2jar.bat (dex2jar.bat的路径)D:\testxml\app\build\outputs\apk\release\classes.dex
(要转换的包的classes.dex的路径)
在这里插入图片描述
这里可以看到提示版本不够,我们下载最新版本就可以了。然后同样执行这个命令,就会在你默认的目录下生成一个名为如下的文件:

(3)然后就用我们专门的查看器就行查看,也就是jd-gui,或者直接用Android Studio查看也可以
直接打开exe,把要查看的东西导入进去,左上文件夹部分
在这里插入图片描述
在这里插入图片描述
就可以查看了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1 . 把apk拷到apktool根目录下,执行:./apktool d xxx.apk,会生成xxx目录,里面有res目录(各种资源文件),smali目录(类似src目录,里面文件的语法不一样)及AndroidManifest.xml。 [*.apk->*.jar: sh ./dex2jar/dex2jar.sh xxx.apk,生成xxx_dex2jar.jar通过jd-linux看源码] 2 . 什么apk汉化啊,就到res/values里string.xml里修改字符串,或者拷贝一份values目录改为values-zh-rCN,再去里面修改string.xml里英文字符串改为中文,所谓的汉化就是这么简单。另外,有些图片里不是中文的得去改图片,那得用Photoshop了,图片也不能乱改,格式,图片大小(尺寸)得原来的。 3 . 修改smali文件,这个有些难度。比如有些apk安装了后要积分什么的,比如大于100才可以用的,其实这个值是用SharedPreference存放的,也就是存在xml里,,位置:/data/data/[包名]/shared_prefs的某个xml里,文件不多肯定是可以找到的。另外一种方法就是修改.smali文件也可以达到这目的,软件实现肯定是读取积分那个值给它修改一下就可以了,例如 const/16 v0 100 (其实就是 v0 = 100)这个语法有点像汇编,觉得还是比汇编简单,v0 v1 ...是寄存器,之前会跟变量关联的。具体的还是自己看看smali语法。 4 . 打包生成apk,执行:./apktool b xxx,会在xxx里面生成,一个dist目录,里面就是xxx.apk,但不能安装滴,提示(Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES]),没有给这个apk签名, 5 . 签名,执行:sh ./dex2jar/d2j-apk-sign.sh ./xxx/dist/xxx.apk 就是给刚才那个apk签名,生成的文件还是xxx.apkapktool根目录下。这样就大功告成啦。 [请看:http://blog.csdn.net/zhouyuanjing/article/details/7446988]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值