ubuntu下android反编译

最近在研究android的逆向工程,看到网上有不少的教程在反编译android源码,但是大多数都是在windows平台下做的。今天,我将简单介绍ubuntu下反编译android源码。

一、工具介绍

1、反编译源码工具:

dex2jar:将apk包中的classes.dex文件反编译成jar包。

jd-gui:将编译好的jar包用该软件打开直接显示为java源码。


2、打包、签名等工具

apktool:资源文件获取,可以提取出图片文件和布局文件进行使用查看,也就是俗称的解包和打包。

sign-master:签名工具,它采用key文件对打包后的apk进行签名。


二、工具下载地址:http://download.csdn.net/detail/icedcap/7407891


三、以微信android版为例简述反编译的过程

1、首先,在微信官方网站下载最新的apk包,解压后的文件如下


将classes.dex反编译成jar包

命令

./dex2jar.sh classes.dex

反编译成功后,将生成一个新的文件classes_dex2jar.jar


利用jd-gui工具打开反编译后的classes_dex2jar.jar文件,工具将自动转化为java源码显示出来,如图:



注意:dex2jar将dex文件转成jar包,jd-gui完成jar包到java文件的转换,这样就可以看到源码了,但是源码往往是混淆过的,看起来很像乱码(这很正常啦,就是为了防止咱们这些人啦!呵呵)


2、好多像我刚接触android反编译的时候都自认为:你既然代码反编译会混淆,那么你的那些资源文件呵呵是不是直接就能用了。这里可定的回答不可用(图片除外),不信你可以试试的。

怎么办呢?这时候要用到解包、打包工具apktool了。

比如拿微信中的AndroidManifest.xml举例吧。

命令:

./apktool d -f weixin530android420.apk weixin.apk

得到解包后的文件夹weixin.apk,如图:


此时的资源文件是可以访问的。并且是以源代码的形式显示不会有混淆的。如图:



3、最后,若是摸清了混淆后的代码,并试着改一些代码从而实现一些破解软件(黑客)就可以尝试打包、签名、发布破解版本了。

作者这里就不多说了,毕竟这样做是不道德的,希望理解。我们都是本着模仿、学习、进步的态度来研究android逆向工程的。


好了,以上便是全部内容了。









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.apk在apktool根目录下。这样就大功告成啦。 [请看:http://blog.csdn.net/zhouyuanjing/article/details/7446988]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值