Android常用adb命令总结

2017年8月30日09:52:47 发表评论 6 views

Android调试桥

adb其实就是Android Debug Bridge,Android调试桥的缩写,adb是一个C / S架构的命令行工具,主要由3部分组成:

  • 运行在PC端的客户端:可以通过它对Android应用进行安装,卸载及调试

    Eclipse中的ADT,SDK工具目录下的DDMS,Monitor等工具,都是同样地用到了adb的功能来与Android设备进行交互

    。PC端的手机助手,诸如360手机助手,豌豆荚,应用宝等,其中除了安装第三方应用方便,其他的功能,基本上都可以通过adb命令去完成,这里建议测试人员尽量不要在电脑上安装这些手机助手,因为其自带的adb程序可能会与Android SDK下的adb程序产生冲突,5037端口被占用,导致使用adb命令时无法连接到设备

  • 运行在PC端的服务:其管理客户端到Android设备上adb后台进程的连接

    adb服务启动后,Windows可以在任务管理器中找到adb.exe这个进程

  • 运行在Android设备上的adb后台进程

    执行adb shell ps | grep adbd,可以找到该后台进程,windows请使用findstr替代grep

    [xuxu:~]$ adb shell ps | grep adbd
    root      23227 1     6672   832   ffffffff 00019bb4 S /sbin/adbd
    

    这里注意一个地方,就是ADB使用的端口号,5037,必要有记一下

    接下来我将ADB命令分为三部分进行介绍,adb 命令adb shell 命令linux 命令

adb命令

在开发或者测试的过程中,我们可以通过adb来管理多台设备,其一般的格式为:

adb [-e | -d | -s <设备序列号>] <子命令>

在配好环境变量的前提下,在命令窗口当中输入adb help或者直接输入adb,将会列出所有的选项说明及子命令。

这里介绍一些里面常用的命令:

  • adb设备,获取设备列表及设备状态
    [xuxu:~]$ adb devices
    List of devices attached 
    44c826a0    device  
    
  • adb get-state,获取设备的状态
    [xuxu:~]$ adb get-state  
    device
    

    设备的状态有3钟,deviceoffline ,unknown

    设备:设备正常连接

    离线:连接出现异常,设备无响应

    未知:没有连接设备

  • adb kill-server,adb start-server,结束adb服务,启动adb服务,通​​常两个命令一起用

    一般在连接出现异常,使用adb设备未正常列出设备,设备状态异常时使用kill-server,然后运行start-server进行重启服务

  • adb logcat,打印Android的系统日志,这个可以单独拿出来讲
  • adb bugreport,打印dumpsys,dumpstate,logcat的输出,也是用于分析错误

    输出比较多,建议重定向到一个文件中

    adb bugreport > d:\bugreport.log
    
  • adb install,安装应用,覆盖安装是使用-r选项

    windows下如果需要安装含有中文名的apk,需要对adb进行修改,百度可以找到做出修改的adb,支持中文命令的apk,请自行搜索

  • adb uninstall,卸载应用,后面跟的参数是应用的包名,请区别于apk 文件名

    '-k'表示保存数据和缓存目录,-k选项,卸载时保存数据和缓存目录

  • adb pull,将Android设备上的文件或者文件夹复制到本地

    例如复制Sdcard下的pull.txt文件到D盘:
    adb pull sdcard/pull.txt d:\
    

    如果需要重命名为rename.txt:

    adb pull sdcard/pull.txt d:\rename.txt
    

    注意权限,复制系统权限的目录下的文件,需要root,并且一般的Android机root之后并不能使用命令去复制,而需要在手机上使用类似于RE的文件浏览器,先对系统的文件系统进行挂载为可读写后,才能在手机上复制移动系统文件,这里推荐使用小米手机的开发版本,IUNI也是不错滴~~

  • adb push,推送本地文件至Android设备

    例如推送D盘下的push.txt至Sdcard:
    adb push d:\push.txt sdcard/
    

    sdcard后面的斜杠不能少,否则会出现下面的错误:

    [xuxu:~]$ adb push push.txt sdcard
    failed to copy 'push.txt' to 'sdcard': Is a directory
    

    权限问题同拉命令

  • adb root,adb remount,只针对类似小米开发版的手机有用,可以直接已经这两个命令获取root权限,并挂载系统文件系统为可读写状态
  • adb reboot,重启Android设备

    bootloader,重启设备,进入fastboot模式,同adb reboot-bootloader命令

    恢复,重启设备,进入恢复模式,经常刷机的同学比较熟悉这个模式

  • adb forward,将宿主机上的某个端口重定向到设备的某个端口
    adb forward tcp:1314 tcp :8888
    

    执行该命令后所有发往宿主机1314端口的消息,数据都会转发到Android设备的8888端口上,因此可以通过远程的方式控制Android设备。

  • adb连接远程连接Android设备

    手机,PC处理相同的网络下,手机安装应用adbWifi,启动连接。手机需要获取root权限(不会的话jj剁了)

    接着运行adb connect 192.168.1.102,即可通过无线的方式连接手机,缺点是速度比较慢

adb shell命令

有人问过我,为什么会知道这么多的命令,答案就是我比较爱折腾,这里大家先要了解我为什么要区区adb命令和adb shell命令。
简单点讲,adb命令是adb这个程序自带的一些命令,而adb shell则是调用的Android系统中的命令,这些Android特有的命令都放在了Android设备的系统/ bin目录下,例如我再命令行中敲这样一个命令:

[xuxu:~]$ adb shell hehe
/system/bin/sh: hehe: not found

很明显,在bin目录下并不存在这个命令。
自己爱折腾,想看看有哪些命令,也不想去找文档,于是启启模拟器,将整个system/bin目录复制了出来,然后一个一个的去试。囧~~ 

打开这些文件就可以发现,里面有些命令其实是一个shell脚本,例如打开猴文件:

# Script to start "monkey" on the device, which has a very rudimentary
# shell.
#
base=/system
export CLASSPATH=$base/framework/monkey.jar
trap "" HUP
exec app_process $base/bin com.android.commands.monkey.Monkey $*

再比如打开

  1. #!/system/bin/sh
  2. #
  3. # Script to start "am" on the device, which has a very rudimentary
  4. # shell.
  5. #
  6. base=/system
  7. export CLASSPATH=$base/framework/am.jar
  8. exec app_process $base/bin com.android.commands.am.Am "$@"

还有SDK源/ android-20 / com / android / commands目录下:

[xuxu:...oid-20/com/android/commands]$ pwd
/Users/xuxu/utils/android/android-sdk-macosx/sources/android-20/com/android/commands
[xuxu:...oid-20/com/android/commands]$ ll   
total 0
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 am
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 bmgr
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 bu
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 content
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 ime
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 input
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 media
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 pm
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 requestsync
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 settings
drwxr-xr-x  7 xuxu  staff   238B  4  2 10:57 svc
drwxr-xr-x  6 xuxu  staff   204B  4  2 10:57 uiautomator
drwxr-xr-x  3 xuxu  staff   102B  4  2 10:57 wm

下面介绍一些常用的adb shell命令

PM

软件包管理器,可以使用获取到一些安装在Android设备上的应用信息,直接运行adb shell pm可以获取到该命令的帮助信息

  • pm列表包列出安装在设备上的应用

    不带任何选项:列出所有的应用的包名(不知道怎么找应用的包名的同学看这里)

    adb shell pm list package
    

    -s:列出系统应用

    adb shell pm list package -s 
    

    -3:列出第三方应用

    adb shell pm list package -3
    

    -f:列出应用包名及对应的apk名及存放位置

    adb shell pm list package -f
    

    -i:列出应用包名及其安装来源,结果显示例子:

    package:com.zhihu.android installer=com.xiaomi.market

    adb shell pm list package -i
    

    命令最后增加过滤器:过滤关键字,可以很方便地查找自己想要的应用

    数组合使用,例如,查找三方应用中知乎的包名,apk存放位置,安装来源:

    [xuxu:~]$ adb shell pm list package -f -3 -i zhihu
    package:/data/app/com.zhihu.android-1.apk=com.zhihu.android  installer=com.xiaomi.market
    
  • pm路径列出对应包名的.apk位置
    [xuxu:~]$ adb shell pm path com.tencent.mobileqq
    package:/data/app/com.tencent.mobileqq-1.apk
    
  • 下列可能参考-f(与pm list package中一样),以及[TARGET-PACKAGE]
  • pm转储,后跟包名,列出指定应用的转储信息,里面有各种信息,自行查看adb shell pm dump com.tencent.mobileqq
    Packages:
    Package [com.tencent.mobileqq] (4397f810):
    userId=10091 gids=[3003, 3002, 3001, 1028, 1015]
    pkg=Package{43851660 com.tencent.mobileqq}
    codePath=/data/app/com.tencent.mobileqq-1.apk
    resourcePath=/data/app/com.tencent.mobileqq-1.apk
    nativeLibraryPath=/data/app-lib/com.tencent.mobileqq-1
    versionCode=242 targetSdk=9
    versionName=5.6.0
    applicationInfo=ApplicationInfo{43842cc8 com.tencent.mobileqq}
    flags=[ HAS_CODE ALLOW_CLEAR_USER_DATA ]
    dataDir=/data/data/com.tencent.mobileqq
    supportsScreens=[small, medium, large, xlarge, resizeable, anyDensity]
    usesOptionalLibraries:
    com.google.android.media.effects
    com.motorola.hardware.frontcamera
    timeStamp=2015-05-13 14:04:24
    firstInstallTime=2015-04-03 20:50:07
    lastUpdateTime=2015-05-13 14:05:02
    installerPackageName=com.xiaomi.market
    signatures=PackageSignatures{4397f8d8 [43980488]}
    permissionsFixed=true haveGids=true installStatus=1
    pkgFlags=[ HAS_CODE ALLOW_CLEAR_USER_DATA ]
    User 0:  installed=true blocked=false stopped=false notLaunched=false enabled=0
    grantedPermissions:
    android.permission.CHANGE_WIFI_MULTICAST_STATE
    com.tencent.qav.permission.broadcast
    com.tencent.photos.permission.DATA
    com.tencent.wifisdk.permission.disconnect
    
  • pm安装,安装应用

    目标apk存放于PC端,请用adb安装

    目标apk存放于Android设备上,请用pm安装安装

  • pm卸载,卸载应用,同时adb uninstall,后面跟的参数都是应用的包名
  • 清除应用数据
  • pm set-install-location,pm get-install-location,设置应用安装位置,获取应用安装位置

    [0 / auto]:默认为自动

    [1 / internal]:默认为安装在手机内部

    [2 / external]:默认安装在外部存储

输入

这个命令可以向Android设备发送按键事件,其源码Input.java

  • 输入文本,发送文本内容,不能发送中文
    adb shell input text test123456
    

    前提先将键盘设置为英文键盘

  • 输入keyevent,发送按键事件,其源码IKeyEvent.java
    adb shell input keyevent KEYCODE_HOME
    

    模拟按下主键,源码里面有定义:

    public static final int KEYCODE_HOME = 3; 

    因此可以将命令中的KEYCODE_HOME替换为3

  • 输入点击,对屏幕发送一个触摸事件
    adb shell input tap 500 500
    

    点击屏幕上坐标为500 500的位置

  • 输入滑动,滑动事件
    adb shell input swipe 900 500 100 500
    

    从右往滑动屏幕

    如果版本不低于4.4,可以模拟长按事件

    adb shell input swipe 500 500 501 501 2000
    

    其实就是在小的距离内,在较长的持续时间内进行滑动,最后表现出来的结果就是长按动作

到这里会发现,MonkeyRunner能做到的事情,通过adb命令都可以做得到,如果进行封装,会比MR做得更好。

屏幕

截图命令

adb shell screencap -p /sdcard/screen.png

截屏,保存至sdcard目录

屏幕录像

4.4新增的录制命令

adb shell screenrecord sdcard/record.mp4

执行命令后操作手机,ctrl + c结束录制,录制结果保存至sdcard

输入法,其源码Ime.java

[xuxu:~]$ adb shell ime list -s                           
com.google.android.inputmethod.pinyin/.PinyinIME
com.baidu.input_mi/.ImeService
	列出设备上的输入法
[xuxu:~]$ adb shell ime set com.baidu.input_mi/.ImeService
Input method com.baidu.input_mi/.ImeService selected    	选择输入法

日志

这个命令很有意思,可以在logcat里面打印你设定的信息,具体用途自己思考!

adb shell log -p d -t xuxu "test adb shell log"

-p:优先级,-t:标签,标签,后面加上消息

[xuxu:~]$ adb logcat -v time -s xuxu               
--------- beginning of /dev/log/system
--------- beginning of /dev/log/main
05-15 13:57:10.286 D/xuxu    (12646): test adb shell log  

getprop

查看Android设备的参数信息,只运行adb shell getprop,结果以key : value键值对的形式显示,如要获取某个键的值:

adb shell getprop ro.build.version.sdk
	获取设备的sdk版本

结束

补充一个引号的用途:场景
1,在PC端执行猴子命令,将信息保存至D盘monkey.log,会这么写:

adb shell monkey -p com.android.settings 5000 > d:\monkey.log

场景2,在PC端执行猴命令,将信息保存至手机的Sdcard,可能会这么写:

adb shell monkey -p com.android.settings 5000 > sdcard/monkey.log

这里肯定会报错,因为最终是写向了PC端当前目录的sdcard目录下,而非非写向手机的Sdcard

这里需要用上引号:

adb shell "monkey -p com.android.settings 5000 > sdcard/monkey.log"

对这些命令都熟悉之后,那么接下来就是综合对编程语言的应用,思考如何用语言去处理这些命令,使得这些命令更加的方便于测试工作。

  • yiisaa
  • 这是我的微信扫一扫
  • weinxin
  • zhengweiqiangcom
  • 我的微信公众号扫一扫
  • weinxin

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: