adb,aapt等命令使用

adb

        install/uninstall:安装/卸载手机中的应用。
        devices:查看当前连接到电脑中的设备。

adb shell

        首先运行adb shell,此时光标前面会变成$。
        ls:列出当前目录下的所有文件和文件夹。
        mkdir:创建文件夹,make directory的缩写。
        pwd:列出当前所在的目录。
        cd:进入到某一个目录,change directory的缩写。定义文件路径时:..代表当前目录的上一级目录,可以多次使用;.[点]代表当前目录。因此,cd ..是退回上级目录。
        rmdir:删除某个文件夹,remove directory的缩写。它不能删除非空文件夹。
        rm:删除指定的文件,是remove的缩写。使用rm -r用于删除非空文件夹。也就是说:rm删除文件,不删除文件夹;rmdir删除空文件夹,不删除文件;rm -r删除非空文件夹,也可用于删除文件。
        mv src dst:移动,move的缩写。src与dst在同一目录下时,可以用来重命名文件。即可用来操作文件,也可用来操作文件夹(空或非空都行)。
        cp src dst:将src指定的文件复制到dst中,copy的缩写。cp用于复制单个文件,cp -r用于复制文件夹(无论为空还是不为空),也可用来复制文件。
        -r:命令后跟-r,表示在指定的目录中递归地进行操作——对目录下的所有文件或文件夹进行相同的操作。
        cat:将指定的文件的内容输出的屏幕上。
        grep “string" file:在指定的文件中查找string。后跟-i表示忽略大小写。后跟-r表示在当前指定目录的文件中递归查找指定的string。
        gzip:将指定的文件(不能是文件夹)压缩成gz文件。如gz qq.txt会将qq.txt文件压缩成qq.txt.gz。
        gzip -d:对指定的gz文件进行解压。
        ping:与win上命令含义一样。
        df:查看磁盘使用情况。
        exit:退出adb shell交互。
        dumpsys:查看当前系统中任务栈以及栈内各activity的信息等。可以使用重定义(>)功能将输出的信息导出到指定的文件中。
        screencap -p xxx.png:截图保存到指定位置。在cmd中运行不需要权限。
        ps:查看当前系统中的所有进程。后可跟|grep package_name来查看指定包名的应用的进程。如:

打包过程

android打包成可执行的apk文件分为以下几个过程:
        1,使用dx将.class编译成.dex文件。
        2,使用aapt将工程中的资源文件打包成.apk。

        3,使用aapt将.dex文件添加到.apk文件中。

        4,使用aapt将.so添加.apk文件中

        5,使用apksigner对生成的apk文件进行签名。

aapt

        全称是android asset packaging tool——android资源打包工具。参考。其作用有二:1,将资源文件生成apk文件;2,将.dex,.so文件添加到生成的apk文件中,从而形成一个完整的apk文件。

package

        该命令主要用于将资源打包成apk文件。如下:
[plain] view plain copy
 
  1. aapt package -f -M ./app/src/main/AndroidManifest.xml -S ./app/src/main/res -S ./lib1/src/main/res -S ./lib2/src/main  
  2. /res -I D:androidsdkplatformsandroid-25android.jar -F test.apk --auto-add-overlay  
        -M指主应用的清单文件,第一个-S指主应用的res文件,后面-S是library工程的res文件,-I指android.jar的所在路径,-F指apk文件的输出路径。
        该命令会将所有资源打包成一个apk文件,但该文件只包含res目录下手资源以及相应的清单文件。
        如果主工程与lib工程有同名的资源文件,则以-S在前的为主。
        -S指向的是添加res目录下的资源,也可以通过-A指定添加assets目录下的资源——assets资源的覆盖规律与res是一样的。

add与remove

        add可以向指定的apk文件中添加文件(如dex文件或者.so文件等),remove可以从指定的apk文件中移除文件。例如上面的先将资源生成apk文件后,可以通过add命令将dex文件添加到apk中。如:
[plain] view plain copy
 
  1. C:UsersxxDesktopapp-release>aapt add test.apk classes.dex  
  2.  'classes.dex'...  
  3.   
  4. C:UsersxxDesktopapp-release>aapt remove test.apk xx.dex  
        第一行是向apk文件中添加dex文件,第二行是从apk中移除xx.dex文件。
        添加.so文件:
[plain] view plain copy
 
  1. C:Usershufeng7Desktopapp-release>aapt add test.apk lib/x86_64/libnative-lib.so  
        要注意:被add到apk文件中的文件,一定不能带前缀,否则就会在apk中创建同名的文件。如上面添加dex文件时,如果写成./dex,那么在apk中首先会创建一个文件名为.的文件夹,然后将classes.dex文件放到该目录下。
        一个apk完整的情况是:dex文件在最上级,不需要目录;lib也在最上级,不需要目录,lib下的所有文件就跟开发时lib文件夹中一样;res也在最上级,res也在最上级,其下的目录也与开发时目录一致。所以上面添加so文件时,不需要在前面加上./[代表当前目录]。

签名apksigner

        可使用apksigner对apk进行签名。可参考官网文档。示例如下:
[plain] view plain copy
 
  1. D:androidsdkuild-tools25.0.2>apksigner sign --ks C:/Users/xx/Desktop/c  
  2. ompany/test.jks --out C:UsersxxDesktopdiyidian2.apk diyidian.apk  

        第一个apk文件(即--out后指定的值)是签名后生成的文件的位置,第二个apk是要被签名的文件。如果没有指定--out,则签名之后的apk会覆盖掉未签名的apk。

        --ks指的是签名文件所在的位置。

dx与dexdump

        dx:用于将.class文件转成.dex文件(或者是.jar,.zip文件)。如:

[plain] view plain copy
 
  1. dx --dex [--output=<file>] [<file>.class | <file>.{zip,jar,apk} | <directory>]  

        --output后跟的是目标路径。最后是class文件的路径或者zip,jar,apk文件路径。

        dexdump:用于获取dex文件中dalvik字节码。如dexdump -d将dex文件还原成dalvik字节码。

总结

        结合反编译以及打包、签名,就可以将一个apk进行反编译后再进行安装了。
        1,首先反编译,拿到smali文件与资源文件。
        2,通过aapt package将资源文件打包成apk文件。
        3,修改smali文件,并打包成dex文件。
        4,通过aapt add将dex文件导入到apk文件中——如果有lib,也需要将lib导入。
        5,将apk文件进行签名。
原文地址:https://www.cnblogs.com/bydzhangxiaowei/p/8172801.html