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鍾,
device
,offline
,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 $*
再比如打開
#!/system/bin/sh
#
# Script to start "am" on the device, which has a very rudimentary
# shell.
#
base=/system
export CLASSPATH=$base/framework/am.jar
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設備上得應用信息
的源代碼Pm.java,直接運行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,發送按鍵事件,KeyEvent.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"
對這些命令都熟悉之後,那麼接下來就是綜合對編程語言的應用,思考如何用語言去處理這些命令,使得這些命令更加的方便於測試工作。