zoukankan      html  css  js  c++  java
  • ApkTool反编译和重新打包

    有时会需要反编译APK,各人有各人的原因,你都懂的……


          准备工作:                            

    下载APKTool,通过下面这个连接进行下载,https://code.google.com/p/android-apktool/downloads/list

    windows下只需要下载这两个文件包即可:apktool1.5.2.tar.bz2和apktool-install-windows-r05-ibot.tar.bz2

    分别解压到到一个方便操作的目录下,然后就可以通过控制台进行操作了,当然前提是你配置已经有了JAVA环境,这个网上一搜一大堆,就不赘述了。


           反编译:                               

    把要反编译的APK文件放到跟APKTool四个文件的同一个目录下;

    打开控制台,跳到该目录(例如是C:\Windows),执行:

        cd C:\Windows                                                 

    然后执行:

       apktool d apkname.apk  foldername    

    apkname.apk 表示要进行反编译的APK文件,foldername表示反编译后文件存放的目录,即在当前目录下会自动建一个新目录存放(如:C:\Windows\foldername

    执行完上面语句后,如果没有出现错误提示,则成功反编译了,找到foldername目录,打开smali目录即为反编译出来的字节。

    但我在执行上面语句后,却出现了错误提示:


    • Exception in thread "main" brut.androlib.err.UndefinedResObject: resource spec:  
    • 0x010300dd 

      根据提示描述是找不到资源文件,应该是要反编译的APK文件用到了系统的一些资源。

      解决办法:

      从手机中导出framework-res.apk文件,该文件是/system/framework下面,把这个文件拷到跟apkTool同一个目录下,执行以下语句把资源文件加进来:

          apktool if freagmework-res.apk            

      执行完以后就可以把framework-res.apk导进来。此时再执行apktool d即可以正常反编译了。

      由于反编译出来的是字节码,所以想修改软件逻辑就需要知道一点字节码的知识,可以看这里:寄存器类型、函数和成员操作符号

      在这里列举几个常用的逻辑符号的对应smali语法:

       

      符号 smali语法
      == if-eq
      != if-ne
      equals if-eqz
      !equals if-nez

      修改完代码逻辑后,就要重新打包成APK文件了:

        apktool b foldername       

      其中foldername即放反编译结果的目录,执行成功后会在该目录的dist目录下有一个重新打包后的apk文件。

      当然我在重新打包时出现了错误提示:

       

      Exception in thread "main" brut.androlib.AndrolibException: brut.directory.PathN
      otExist: apktool.yml

      从字面上理解就是找不到apktool.yml这个文件,如果在执行apktool d后能正常反编译,在目录中是会存在apktool.yml文件的,我之所以出现这个错误,是因为在反编译时出现了上面提到的“资源找不到”错误后,我看到反编译出了字节码,就没有理会它导致的。


      好啦,到此就成功打包了一个新的apk文件了,但还不要高兴得太早,该文件是一个没有签名的apk,有了解过android的应该都知道,没有签名是无法安装的。那就要重新为该文件签一下名了。把你的签名文件和apk拷到同一个目录下,然后执行以后语句即可:

         jarsigner -verbose -keystore wendy.keystore -signedjar wendy_signed.apk wendy.apk wendy.keystore        

      这里输入wendy.keystore即你的签名文件名称,文件wendy.apk,最终生成wendy_signed.apk为Android签名后的APK执行文件。


      大功告成!!!

      参考文章:

      http://blog.creke.net/786.html

      http://blog.csdn.net/caszhao/article/details/6030425

      http://danqingdani.blog.163.com/blog/static/1860941952012103041246686/

      http://blog.csdn.net/wenhaiyan/article/details/5520964



       
    • Exception in thread "main" brut.androlib.err.UndefinedResObject: resource spec:  
    • 0x010300dd 
       
  • 相关阅读:
    akka设计模式系列-actor锚定
    Akka源码分析-Remote-位置透明
    Akka源码分析-Remote-网络链接生命周期
    Akka源码分析-Remote-收消息
    Akka源码分析-Remote-网络链接
    Akka源码分析-Remote-发消息
    Akka源码分析-Remote-Actor创建
    Akka源码分析-Remote-ActorSystem
    Akka源码分析-ask模式
    Akka源码分析-深入ActorRef&ActorPath
  • 原文地址:https://www.cnblogs.com/jiangu66/p/3038721.html
Copyright © 2011-2022 走看看