linux下的APK反编译软件及过程介绍 .

本文详细介绍了一套完整的安卓APK文件反编译流程,包括使用apktool、dex2jar等工具提取资源文件、反编译源代码的具体步骤。

须要工具:
  1.apktool apk打包工具
  下载地址:http://android-apktool.googlecode.com/files/apktool1.5.2.tar.bz2
  安装:直接解压就可以,是一个apktool.jar文件。通过

  1. $java -jar apktool.jar  
  $java -jar apktool.jar

  来执行。依赖于java执行环境

  2.dex2jar dex转化jar工具
  下载地址:http://dex2jar.googlecode.com/files/dex2jar-0.0.9.15.zip
  安装:直接解压就可以,是一个目录,里面包括了非常多文件。通过

  1. $./dex2jar.sh  
$./dex2jar.sh

  来执行

  3.假设你没有unzip。安装此解压工具, zip解压缩工具,用于解压jar包(jar包是zip压缩的,所以能够用其他工具取代)
  下载地址:ubuntu $sudo apt-get install unzip
  安装: $sudo apt-get install unzip

  1. $upzip [src_path] -d [dst_path]  
        $upzip [src_path] -d [dst_path]

  来执行

  4.jad .class文件反编译工具
  下载地址:http://www.varaneckas.com/jad

       http://varaneckas.com/jad/jad158e.linux.static.zip
  安装:直接解压就可以,是一个可运行文件,通过  

       ./jad

  来执行。须要说明的是。这个须要下载static版本号的,假设不行的话,在去第一个链接里找还有一个下载。


  接下来。工具准备完成了,最好设定一下环境变量。我们就能够反编译apk了

  一、抽取apk资源

      运行: $java -jar apktool.jar d [source.apk]

  二、反编译源代码

  (1)解压apk

  1. $unzip [source.apk] -d [step_1]  
  $unzip [source.apk] -d [step_1]

  step_1指的是你所须要解压到的文件夹

  (2)进入step_1 文件夹,找到classes.dex文件,将dex文件转化成jar文件

  1. $dex2jar.sh classes.dex  
$dex2jar.sh classes.dex

  (3)获得一个classes_dex2jar.jar文件。我们如今要再度解压这个文件

  1. $upzip classes_dex2jar.jar -d [step_3]  
        $upzip classes_dex2jar.jar -d [step_3]

  step_3指的是你解压到的文件夹

  (4)我们获得一个step_3文件夹。我们接下来要反编译该文件夹下全部.class文件  

  1. $./jad -o -r -s  java -d  src step_3/**/*.class  
        $./jad -o -r -s  java -d  src step_3/**/*.class

       对于上面的參数,能够直接运行./jad查看,或者Readme.txt查看

  (5)我们再度获得一个src文件夹,该文件夹下就是反编译好的源代码文件了。

也能够使用JD-GUI工具直接查看classes_dex2jar.jar的class文件。

     


 假设以上命令不运行的话,查看文件夹是否正确。


转载于:https://www.cnblogs.com/gavanwanggw/p/7136403.html

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、付费专栏及课程。

余额充值