安卓apk反编译教程,Android 如何对apk文件进行反编译以及重新

1,Android 如何对apk文件进行反编译以及重新第一:使用apktool直接反编译apk第二:apk中包含的内容第三:进入到hellodemo\smali\com\example\hello,打开MainActivity.smali 。找到:const-string v1, "\u4f60\u597d",修改为:const-string v1, "hello",第四:然后在命令行输入:apktool b hellodemo hellodemo1.apk 。这回重新打包成hellodemo1.apk 。第五:然后给新生成的apk进行签名 。把这个apk拷贝到autosign的目录下面,然后切换过去,在命令行输入:java -jar signapk.jar testkey.x509.pem testkey.pk8 hellodemo1.apk hellodemo.apk 。第六:把生成的hellodemo.apk安装到手机,可以看到主界面上已经显示的是hello , 而不再是你好 。说明反编译重新打包成功!
2,安卓studio解包修改重编译一个apk1.查看APKTool的版本: 控制台输入apktool和apktool -version进行验证 2.反编译apk并修改代码:在apk所在目录控制台输入下面指令,即可将文件名为source的apk反编译到outDir目录中apktool d -o outDir source.apk3.修改编译出的代码,可以更改res资源,manifests等 。如果修改版本号:打开输入目录outDir找到apktool.yml文件,编辑修改versionCode4.重新打包 : 通过以下命令就可以将目录outDir中的文件重新打包为no_sign_result.apkapktool b -o no_sign_result.apk outDir5.重新签名:使用如下命令进行签名jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore demostore.jks -signedjar result-signed.apk no_sign_result.apk yourkey注:demostore.jks为签名文件、yourkey为签名的key、no_sign_result.apk为要签名的源文件、result-signed.apk为签名后的目标文件
3 , 安卓apk文件如何反编译安卓apk文件反编译:一、反编译xml文件1> 首先下载我给你们提供的文件夹apk_fanbianyi,把它放到某个盘的根目录下(为了方便输入dos命令),然后打开apktool文件夹,安装win+r键,然后输入cmd,进入dos命令行,大家别怕,不用晕,很简单的 。2> 然后在dos命令中首先输入文件夹所在盘符+“:”回车,接着再输入cd+apktool所在目录,切换dos工作空间到apktool文件夹下 。3> 接着输入 apktool.bat d 【需反编译apk文件路径】 {【反编译文件反编译后的路径】},其中最后一部分可以省去,系统会默认把apk文件反编译到apktool目录下,例如输入 apktool.bat d d:/apk_fanbianyi/ttkp.apk,在apktool文件夹下就会生成一个ttpk的文件夹,所有的xml文件全部反编译成功 。二、反编译java文件1> 首先解压需要反编译的apk文件 , 拷贝出里面的classes.dex文件到dex2jar文件夹(为了方便操作,省去dos命令输入路径的麻烦)2> 把工作空间切换到dex2jar文件夹下 , 输入命令cd d:/apk_fanbianyi/dex2jar回车3> 输入命令dex2jar.bat classes.dex回车,发现dex2jar文件夹下多了一个classes_dex2jar.jar文件,这是反编译成功的java文件三、xml文件的打开1> 打开apktool文件夹下的ttkp文件夹,任意找到一个xml文件,选中单击右键 , 选择notepad++打开(需下载),如果没有此软件,可以选择打开方式,选择记事本打开四、java文件的打开1> dex2jar文件夹下的classes_dex2jar.jar拷贝到apktool文件夹的ttkp文件夹中 , 不能用notepad++打开,不然会乱码的2> 启动apk_fanbianyi文件夹下的jd-gui.exe,然后点左上角file,选择open file,找到classes_dex2jar.jar文件 , 可以发现有很多包,选择包下的任意一个java文件,打开不乱码了,是不是很神奇,哈哈,你学会了安卓apk文件反编译【安卓apk反编译教程,Android 如何对apk文件进行反编译以及重新】
4 , Android 将 apk 反编译为源码将apk解压 , 在解压后的文件夹中可以找到classes.dex文件 。(除了classes.dex文件 , 可能还会有classes2.dex ,classes3.dex等等 , 本文以classes.dex为例 , 对其他几个dex文件的操作是类似的)使用dex2jar工具,将dex文件转换为jar文件使用方式:执行命令后 , 生成的classes-dex2jar.jar就是我们需要的jar文件 。使用Luyten工具查看jar文件 , 就能看到反编译后的源码了 。本例中, classes.dex文件中存储的是android的一些基础库,实际编写的源码在classes3.dex中,对classes3.dex执行第二步,查看生成的classes3-dex2jar.jar文件,可以看到如下内容:这就是反编译apk的基本操作了 。Cmder是一个非常好用的命令行工具 。效果如下:只需要执行apk2jar命令,就可以实现把apk解压到apk_文件夹中 , 并将apk_文件夹中的classes.dex文件转换为jar。原理就是通过Cmder添加别名 , 把上述的第一步和第二步中执行的命令行组合起来了 。为Cmder添加别名很简单,编辑Cmder安装目录\config\user_aliases.cmd文件 , 将别名添加到里面即可 。本例添加的别名如下:其中:5 , 如何进行APK反编译如何进行APK反编译我们下载到某些apk的时候 , 可能总想学习下别人是怎么进行程序设计的,或者怎样使用xml文件布局的,这时就想到将apk文件的后缀改为rar并解压,最终得到一些图片资源和很多打开为乱码的文件 , 可见这种方式不可行 , 这就需要使用下面的工具对apk进行反编译了 。一、工具准备:apktool、dex2jar、jd-gui工具包也可以在这里下载 。1、dex2jar可以在这里下载 , jd-gui可以在这里下载 。2、apktool,可以到Google官方下载 , apktool-1.0.0.tar.bz2(里面有apktool.jar)和apktool-install-windows-2.1_r01-1.zip两个包都要下 。解压apktool.jar到 C:\Windows,解压apktool-install-windows.zip到任意文件夹(例如E盘根目录) 。二、使用dex2jar + jd-gui 得到apk的java源码,步骤如下:1、用.rar打开apk文档,将classes.dex文件解压出来,然后使用工具反编译成.jar文件 。在cmd下进入dex2jar.bat所在路径 , 然后输入“dex2jar.bat XXX”,XXX指的是你要反编译的apk中的classes.dex文件所在路径及名称 , 比如:我的dex2jar.bat在D:\Android\apk_decode\dex2jar-0.0.7-SNAPSHOT路径下,classes.dex在D:\Android下 , 所以你进入到dex2jar.bat路径后 , 输入dex2jar.bat D:\Android\classes.dex , 这样会生成一个jar文件 。2、用jd-gui反编译工具将得到.jar文件反编译成.java文件 。三、使用apktool得到apk的xml文件1、Win+R 运行CMD,用cd命令转到apktool-install-windows所在文件夹,输入命令:apktool d XXX.apk ABC反编译XXX.apk到文件夹ABC2、 在解压后的文件夹中可以得到apk的xml配置文件 。四、第二步得到的程序源代码和第三步得到的xml文件组合下,就成一个android工程 , 即可得到完整的apk源码 。6 , 反编译Android APK的具体步骤是怎样的1、配置好JAVA环境变量,下载:apktool解压的文件放在C盘根目录的apktool文件夹里(apktool文件夹自己创立)2打开命令提示符,(开始-运行-输入cmd)3输入:cd \apktool 系统指令到了apktool文件夹(这里就是为什么要把解压的apktool解压的文件放到apktool文件夹的原因,当然你也可以自命名文件夹的名称,那么比如arc,那么指令就变成了:cd \arc 前提是你必须把apktool解压的文件放到这个文件夹里面)4使用RE管理器把系统里面的framework-res.apk 与 SystemUI.apk 提取出来放在apktool文件夹里面5 如果只是想反编译framework-res.apk输入apktool if framework-res.apk(框架的建立)6开始最重要的反编译,输入指令,apktool d framework-res.apk(反编辑的APK一定要用没换过图片的,否则回编辑失败)7最后反编译完成修改代码完成后 , 输入代码:apktool d framework-res 即可完成回编译8回编译后的新的 apk在framework/dis 文件夹里面9如果反编译的是系统文件 , 比如,SystemUI.apk 那么必须进行挂载框架 , 反编译时 , 必须敲入一下命令:(然后再重复7-9步骤)apktool if framework-res.apkapktool if SystemUI.apk10对于三星手机(比如9100、9108/9100G),如果反编译SystemUI.apk要敲入一下命令进行框架挂载apktool if framework-res.apkapktool if twframework-res.apk apktool if SystemUI.apk11回编译的命令是 apktool b XXX (没有后面的apk后缀)反编译的命令是 apktool d xxx(有后面的apk)反编译步骤方法:一、apk反编译得到程序的源代码、图片、XML配置、语言资源等文件下载上述工具中的apktool,解压得到3个文件:aapt.exe,apktool.bat,apktool.jar,将需要反编译的APK文件放到该目录下,打开命令行界面(运行-CMD) ,定位到apktool文件夹 , 输入以下命令:apktool.bat d -ftest.apktest(命令中test.apk指的是要反编译的APK文件全名,test为反编译后资源文件存放的目录名称,即为:apktool.batd-f[apk文件 ][输出文件夹])说明获取成功 , 之后发现在文件夹下多了个test文件,点击便可以查看该应用的所有资源文件了 。如果想将反编译完的文件重新打包成apk,那可以:输入apktool.batbtest(编译出来文件夹)便可之后在之前的test文件下便可以发现多了2个文件夹:builddist(里面存放着打包出来的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文件 , 便可以看到源码了被混淆过的效果图(类文件名称以及里面的方法名称都会以a,b,c....之类的样式命名):三、 图形化反编译apk上述步骤一、二讲述了命令行反编译apk,现在提供一种图形化反编译工具:Androidfby首先,下载上述反编译工具包,打开Androidfby目录,双击Android反编译工具.exe,就可以浏览打开要反编译的apk通过反编译 , 可以获知该应用用到了什么第3方的库文件,它的代码是如何编写的等等 。然而,如果该APK进行了混淆处理,那么看到的类文件名称以及里面的方法名称都会以a,b,c....之类的样式命名,所以可以想找到所想得知的界面代码可能会十分费劲 , 找到了代码可能看起来也会很费劲,可是一个大体的思路会获得,有了这个思路,就可以去尝试了 。反编译:一、更改apk文件的后缀名,如:LianyunHelper3.0.11.apk改成LianyunHelper3.0.11.zip二、用zip解压缩LianyunHelper3.0.11.zip文件三、从解压缩的文件夹中取出classes.dex文件并放到dex2jar.bat所在目录四、运行cmd命令,进入dex2jar.bat所在的目录,输入dex2jar.bat classes.dex即可生成classes.dex.dex2jar.jar文件五、用jd-gui工具打开classes.dex.dex2jar.jar文件,即可看到源码六、将AndroidManifest.xml文件放到AXMLPrinter2.jar所在目录,运行cmd命令,进入 AXMLPrinter2.jar所在目录,输入java -jar AXMLPrinter2.jar AndroidManifest.xml > AndroidManifest.txt 。防止反编译:2.3之后的在工程的"default.properties"中添加这样一句话“proguard.config=proguard.cfg”2.3之前的把 proguard.cfg 文件 拷贝到 旧项目里就好了 。apk反编译方法如下:一、更改apk文件的后缀名,如:lianyunhelper3.0.11.apk改成lianyunhelper3.0.11.zip二、用zip解压缩lianyunhelper3.0.11.zip文件三、从解压缩的文件夹中取出classes.dex文件并放到dex2jar.bat所在目录四、运行cmd命令,进入dex2jar.bat所在的目录,输入dex2jar.bat classes.dex即可生成classes.dex.dex2jar.jar文件五、用jd-gui工具打开classes.dex.dex2jar.jar文件,即可看到源码六、将androidmanifest.xml文件放到axmlprinter2.jar所在目录,运行cmd命令,进入 axmlprinter2.jar所在目录,输入java -jar axmlprinter2.jar androidmanifest.xml > androidmanifest.txt 。

    推荐阅读