Android的ADB工具使用

心鑫發表於2013-11-07


在SDK的Tools資料夾下包含著Android模擬器操作的重要命令ADB,ADB的全稱為Android Debug Bridge,就是除錯橋的作用,藉助這個工具,我們可以管理裝置或手機模擬器的狀態 ,還可以進行以下的操作:

(1)快速更新裝置或手機模擬器中的程式碼,如應用或Android系統升級;
(2)在裝置上執行Shell命令;
(3)管理裝置或手機模擬器上的預定埠;

(4)在裝置或手機模擬器上覆制或貼上檔案。

 

ADB的工作方式比較特殊採用監聽Socket TCP 5554等埠的方式讓IDE和Qemu通訊,預設情況下ADB會daemon相關的網路埠,所以當我們執行Eclipse時ADB程式就會自動執行,在Eclipse中通過DDMS來除錯Android程式;也可以通過手動方式呼叫,以下為一些常用的操作供參考。

 

1.版本資訊

D:\unsetup\android-sdk-windows-1.0_r1\tools>adb version

Android Debug Bridge version 1.0.20


2.安裝應用到模擬器 
    adb install [-l] [-r] <file>。

其中file是需要安裝的apk檔案的決定路徑。

 

3.解除安裝已經安裝的應用

(1)方法1:

     adb uninstall [-k] <package>。

其中package表示需要解除安裝的應用的包的名字,k表示是否保留應用的配置資訊和cache資料。

 

(2)手動刪除。
adb shell
cd /data/app
rm app.apk


4.進入裝置或模擬器的Shell
adb shell
    通過上面的命令,就可以進入裝置或模擬器的Shell環境中,在這個Linux Shell中,可以執行各種Linux 的命令,另外如果只想執行一條Shell命令,可以採用以下的方式:
adb shell [command]
如:

D:\unsetup\android-sdk-windows-1.0_r1\tools>adb shell df

/dev: 49564K total, 0K used, 49564K available (block size 4096)

/sqlite_stmt_journals: 4096K total, 0K used, 4096K available (block size 4096)

/system: 69120K total, 65508K used, 3612K available (block size 4096)

/data: 76544K total, 63684K used, 12860K available (block size 4096)

/cache: 69120K total, 1244K used, 67876K available (block size 4096)

 

5.轉發埠

可以使用 forward 命令進行任意埠的轉發—一個模擬器/裝置例項的某一特定主機埠向另一不同埠的轉發請求。下面演示瞭如何建立從主機埠7100到模擬器/裝置埠8100的轉發。

adb forward tcp:7100 tcp:8100

同樣地,可以使用ADB來建立命名為抽象的UNIX域套介面,上述過程如下所示:

adb forward tcp:7100 local:logd


6.複製檔案

可以使用adb pull ,push 命令將檔案複製到一個模擬器/裝置例項的資料檔案或是從資料檔案中複製。install 命令只將一個apk檔案複製到一個特定的位置,與其不同的是,pull 和 push 命令可讓使用者複製任意的目錄和檔案到一個模擬器/裝置例項的任何位置。

從模擬器或者裝置中複製檔案或目錄,使用如下命:

adb pull <remote> <local>

將檔案或目錄複製到模擬器或者裝置,使用如下命令:

adb push <local> <remote>

在這些命令中, <local> 和<remote> 分別指通向自己的發展機(本地)和模擬器/裝置例項(遠端)上的目標檔案/目錄的路徑

下面是一個例子::

adb push foo.txt /sdcard/foo.txt


7.搜尋模擬器/裝置的例項
    取得當前執行的模擬器/裝置的例項的列表及每個例項的狀態,如:

D:\unsetup\android-sdk-windows-1.0_r1\tools>adb devices

List of devices attached

HT843GZ03305    device


8.檢視bug報告 

D:\unsetup\android-sdk-windows-1.0_r1\tools>adb bugreport

========================================================

== dumpstate

========================================================

------ SYSTEM LOG ------

04-12 16:59:46.521 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.

04-12 16:59:46.531 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.

04-12 16:59:46.531 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.

04-12 16:59:46.541 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.

04-12 16:59:47.391 I/ActivityManager(   55): Starting activity: Intent { comp={com.iceskysl.iTracks/com.iceskysl.iTracks.iTracks} }

04-12 16:59:47.641 D/iTracks (23968): renderListView.

04-12 16:59:47.671 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.

04-12 16:59:47.681 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.


9.記錄無線通訊日誌
    一般來說,無線通訊的日誌非常多,在執行時沒必要去記錄,但我們還是可以通過命令,設定記錄:

D:\unsetup\android-sdk-windows-1.0_r1\tools>adb shell

# logcat -b radio

logcat -b radio

D/HTC_RIL (   30): (t=1239390296)<< 0

D/HTC_RIL (   30): (t=1239390296)>> AT@HTCPDPFD=0

D/HTC_RIL (   30): (t=1239390296)<< 0

D/HTC_RIL (   30): (t=1239390296)>> AT+CSQ

D/HTC_RIL (   30): (t=1239390296)<< +CSQ: 29,99

D/HTC_RIL (   30): 0

D/HTC_RIL (   30): (t=1239390296)>> AT+CREG?

D/HTC_RIL (   30): (t=1239390296)<< +CREG: 2,3

D/HTC_RIL (   30): 0


10.獲取裝置的ID和序列號
adb get-product

D:\unsetup\android-sdk-windows-1.0_r1\tools>adb get-serialno

HT843GZ03305

 

 

11.通過遠端Shell端執行AQLite3連線資料庫

通過ADB遠端Shell端,可以通過Android的軟AQLite 3 命令程式來管理資料庫。SQLite 3 工具包含了許多使用命令,例如,.dump 顯示錶的內容,.schema 可以顯示出已經存在的表空間的SQL CREATE結果集。SQLite3還允許遠端執行sql命令。

 

通過SQLite 3 , 按照前面的方法登入模擬器的遠端Shell端,然後啟動工具就可以使用SQLite 3 命令。當SQLite 3 啟動以後,還可以指定想檢視的資料庫的完整路徑。模擬器/裝置例項會在資料夾中儲存SQLite3資料庫/data/data/<package_name> /databases /。

 

示例如下:

$ adb  shell

# sqlite3 /data/data/com.example.google.rss.rssexample/databases/rssitems.db

SQLite version 3.3.12

Enter ".help" for instructions

.... enter commands, then quit...

 

sqlite> .exit

當啟動SQLite 3的時候,就可以通過Shell端傳送SQLite 3,命令了。用exit 或<Ctrl+D>組合鍵退出ADB遠端Shell端。

 

 

 

12.ADB命令列表

下列表格列出了adb支援的所有命令,並對它們的意義和使用方法做了說明.

Category

Command

Description

Comments

Options

-d

僅僅通過USB介面來管理abd

如果不只是用USB介面來管理則返回錯誤

-e

僅僅通過模擬器例項來管理adb

如果不是僅僅通過模擬器例項管理則返回錯誤

-s <serialNumber>

通過模擬器/裝置的允許命令號碼來傳送命令來管理adb (如 “emulator-5556″)

如果沒有指定號碼,則會報錯

General

devices

檢視所有連線模擬器/裝置的設施的清單

檢視 Querying for Emulator/Device Instances 獲取更多相關資訊

help

檢視adb所支援的所有命令

 

version

檢視adb的版本序列號

 

Debug

logcat [<option>] [<filter-specs>]

將日誌資料輸出到螢幕上

 

bugreport

檢視bug的報告,如dumpsys ,dumpstate ,和logcat 資訊

 

jdwp

檢視指定設施的可用的JDWP資訊

可以用 forward jdwp:<pid>埠對映資訊來連線指定的JDWP程式,例如:
adb forward tcp:8000 jdwp:472
jdb -attach localhost:8000

Data

install <path-to-apk>

安裝Android為(可以模擬器/設施的資料檔案.apk指定完整的路徑)

 

pull <remote> <local>

將指定的檔案從模擬器/設施拷貝到計算機上

 

push <local> <remote>

將指定的檔案從計算機上拷貝到模擬器/裝置中

 

Ports and Networking

forward <local> <remote>

用本地指定的埠通過Socket方法遠端連線模擬器/設施

埠需要描述下列資訊:

  • tcp:<portnum>
  • local:<UNIX domain socket name>
  • dev:<character device name>
  • jdwp:<pid>

ppp <tty> [parm]…

通過USB執行ppp:

  • <tty> — the tty for PPP stream. For exampledev:/dev/omap_csmi_ttyl.
  • [parm]… &mdash zero or more PPP/PPPD options, such as defaultroute ,local , notty , etc.

需要提醒的不能自動啟動PDP連線

 

Scripting

get-serialno

檢視adb例項的序列號

檢視 Querying for Emulator/Device Instances 可以獲得更多資訊

get-state

檢視模擬器/設施的當前狀態

wait-for-device

如果裝置不聯機就不讓執行,也就是例項狀態是 device 時

可以提前把命令轉載在adb的命令器中,在命令器中的命令在模擬器/裝置連線之前是不會執行其他命令的,示例如下:

adb wait-for-device shell getprop

需要提醒的是,這些命令在所有的系統啟動起來之前是不會啟動adb的,所以在所有的系統啟動起來之前也不能執行其他的命令,例如,運用install 的時候就需要Android包,這些包需要系統完全啟動,例如:

adb wait-for-device install <app>.apk

上面的命令只有連線上了模擬器/裝置連線上了adb服務才會被執行,而在Android系統完全啟動前執行就會有錯誤發生

Server

start-server

選擇服務是否啟動adb服務程式

 

kill-server

終止adb服務程式

 

Shell

shell

通過遠端Shell命令來控制模擬器/裝置例項

檢視獲取更多資訊 for more information

shell [<shellCommand>]

連線模擬器/設施執行Shell命令,執行完畢後退出遠端Shell端l

 

相關文章