adb,即Android Debug Bridge,它是Android开发/测试人员不可替代的强大工具html
安装brewnode
ruby -e “$(curl –insecure -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)”.
安装adblinux
brew install Caskroom/cask/android-platform-tools
测试是否安装成功, 打开手机开发者模式, 打开USB调式和安装功能android
adb devices
第一次执行会提示没有启动, 会自动启动git
Jackeys-MacBook-Pro:~ jackey$ adb devices List of devices attached * daemon not running; starting now at tcp:5037 * daemon started successfully
再执行一次github
Jackeys-MacBook-Pro:~ jackey$ adb devices
List of devices attached
此次没有提示错误, 但没有列出手机。是由于没有开启手机开发者模式和USB调试安装功能shell
咱们打开后再试一次, 此次就能看到有列出咱们的设备了, device前面一段就是咱们的设备的serialNumber缓存
Jackeys-MacBook-Pro:~ jackey$ adb devices
List of devices attached
62ab58430211 device
经过 USB 链接来正常使用 adb 须要保证几点:安全
硬件状态正常。ruby
包括 Android 设备处于正常开机状态,USB 链接线和各类接口无缺。
Android 设备的开发者选项和 USB 调试模式已开启。
能够到「设置」-「开发者选项」-「Android 调试」查看。
若是在设置里找不到开发者选项,那须要经过一个彩蛋来让它显示出来:在「设置」-「关于手机」连续点击「版本号」7 次。
设备驱动状态正常。
这一点貌似在 Linux 和 Mac OS X 下不用操心,在 Windows 下有可能遇到须要安装驱动的状况,确认这一点能够右键「计算机」-「属性」,到「设备管理器」里查看相关设备上是否有黄色感叹号或问号,若是没有就说明驱动状态已经好了。不然能够下载一个手机助手类程序来安装驱动先。
经过 USB 线链接好电脑和设备后确认状态。
若是能看到
说明链接成功.
除了能够经过 USB 链接设备与电脑来使用 adb,也能够经过无线链接——虽然链接过程当中也有须要使用 USB 的步骤,可是链接成功以后你的设备就能够在必定范围内摆脱 USB 链接线的限制啦!
操做步骤:
将 Android 设备与要运行 adb 的电脑链接到同一个局域网,好比连到同一个 WiFi。
将设备与电脑经过 USB 线链接。
应确保链接成功(可运行 adb devices
看是否能列出该设备)。
让设备在 5555 端口监听 TCP/IP 链接:
adb tcpip 5555
断开 USB 链接。
找到设备的 IP 地址。
通常能在「设置」-「关于手机」-「状态信息」-「IP地址」找到,也可使用下文提到的获取设备IP的方法用 adb 命令来查看。
经过 IP 地址链接设备。
adb connect <device-ip-address>:<port>
这里的 <device-ip-address>
就是上一步中找到的设备 IP 地址, <port>就是上面设置的5555端口。
拔掉USB线, 确认链接状态。
adb devices
若是能看到
Jackeys-MacBook-Pro:xiaoailite jackey$ adb devices List of devices attached 192.168.1.10:5555 device
说明链接成功。
若是链接不了,请确认 Android 设备与电脑是链接到了同一个 WiFi,而后再次执行 adb connect <device-ip-address>:<port>
那一步;
若是仍是不行的话,经过 adb kill-server
从新启动 adb 而后从头再来一次试试。
断开无线链接命令:
adb disconnect <device-ip-address>
adb start-server
adb kill-server
adb version
adb devices
输出:
Jackeys-MacBook-Pro:~ jackey$ adb devices
List of devices attached
62ab58430211 device
输出格式为[serialNumber][state], 其中state有以下几种:
adb [-d|-e|-s <serialNumber>] <command>
在多个设备/模拟器链接的状况下较经常使用的是 -s <serialNumber>
参数,serialNumber 能够经过 adb devices
命令获取
adb -P <port> start-server
默认端口是5037
adb shell ifconfig | grep Mask
adb shell pm list packages
在 adb shell pm list packages
的基础上能够加一些参数进行过滤查看不一样的列表,支持的过滤参数以下:
adb install [-lrtsdg] <path_to_apk>
[100%] /data/local/tmp/1.apk pkg: /data/local/tmp/1.apk Success
adb uninstall [-k] <packagename>
<packagename>
表示应用的包名,-k
参数可选,表示卸载应用但保留数据和缓存目录。
示例:
adb uninstall com.qihoo360.mobilesafe
adb shell pm clear <packagename>
<packagename>
表示应用名包,这条命令的效果至关于在设置里的应用信息界面点击了「清除缓存」和「清除数据」。
示例:
adb shell pm clear com.qihoo360.mobilesafe
adb shell dumpsys activity activities | grep mFocusedActivity
adb shell dumpsys activity services [<packagename>]
<packagename>
参数不是必须的,指定 <packagename>
表示查看与某个包名相关的 Services,不指定表示查看全部 Services。
<packagename>
不必定要给出完整的包名,好比运行 adb shell dumpsys activity services org.mazhuang
,那么包名 org.mazhuang.demo1
、org.mazhuang.demo2
和 org.mazhuang123
等相关的 Services 都会列出来。
adb shell am start [options] <INTENT>
例如调起微信主界面:
adb shell am start -n com.tencent.mm/.ui.LauncherUI
调起 org.mazhuang.boottimemeasure/.MainActivity
并传给它 string 数据键值对 toast - hello, world
adb shell am start -n org.mazhuang.boottimemeasure/.MainActivity --es "toast" "hello, world"
adb shell am startservice [options] <INTENT>
例如调起微信的某Service
adb shell am startservice -n com.tencent.mm/.plugin.accountsync.model.AccountAuthenticatorService
adb shell am broadcast [options] <INTENT>
能够向全部组件广播,也能够只向指定组件广播。
例如,向全部组件广播 BOOT_COMPLETED
:
adb shell am broadcast -a android.intent.action.BOOT_COMPLETED
又例如,只向 org.mazhuang.boottimemeasure/.BootCompletedReceiver
广播 BOOT_COMPLETED
:
adb shell am broadcast -a android.intent.action.BOOT_COMPLETED -n org.mazhuang.boottimemeasure/.BootCompletedReceiver
这类用法在测试的时候很实用,好比某个广播的场景很难制造,能够考虑经过这种方式来发送广播。
既能发送系统预约义的广播,也能发送自定义广播。以下是部分系统预约义广播及正常触发时机:
adb shell am force-stop <packagename>
示例:
adb shell am force-stop com.qihoo360.mobilesafe
复制设备里的文件到电脑
adb pull <设备里的文件路径> [电脑上的目录]
其中 电脑上的目录
参数能够省略,默认复制到当前目录。
示例:
adb pull /sdcard/sr.mp4 ~/tmp/
说明:设备上的文件路径可能须要 root 权限才能访问,若是你的设备已经 root 过,能够先使用 adb shell
和 su
命令在 adb shell 里获取 root 权限后,先 cp /path/on/device /sdcard/filename
将文件复制到 sdcard,而后 adb pull /sdcard/filename /path/on/pc
复制电脑里的文件到设备
adb push <电脑上的文件路径> <设备里的目录>
示例:
adb push ~/sr.mp4 /sdcard/
说明:设备上的文件路径普通权限可能没法直接写入,若是你的设备已经 root 过,能够先 adb push /path/on/pc /sdcard/filename
,而后 adb shell
和 su
在 adb shell 里获取 root 权限后,cp /sdcard/filename /path/on/device
在 adb shell
里有个很实用的命令叫 input
,经过它能够作一些有趣的事情。
input
命令的完整 help 信息以下:
Usage: input [<source>] <command> [<arg>...]
The sources are: mouse keyboard joystick touchnavigation touchpad trackball stylus dpad gesture touchscreen gamepad The commands and default sources are: text <string> (Default: touchscreen) keyevent [–longpress] <key code number or name> … (Default: keyboard) tap <x> <y> (Default: touchscreen) swipe <x1> <y1> <x2> <y2> [duration(ms)] (Default: touchscreen) press (Default: trackball) roll <dx> <dy> (Default: trackball)
好比使用 adb shell input keyevent <keycode>
命令,不一样的 keycode 能实现不一样的功能,完整的 keycode 列表详见 KeyEvent,摘引部分我以为有意思的以下:
下面是input命令的一些用法举例
adb shell input keyevent 26
adb shell input keyevent 82
adb shell input keyevent 3
adb shell input keyevent 4
adb shell input keyevent 24
adb shell input keyevent 25
adb shell input keyevent 164
adb shell input keyevent 85
adb shell input keyevent 86
adb shell input keyevent 87
adb shell input keyevent 88
adb shell input keyevent 126
adb shell input keyevent 127
能够经过上文讲述过的模拟电源键来切换点亮和熄灭屏幕,但若是明确地想要点亮或者熄灭屏幕,那可使用以下方法。
adb shell input keyevent 224
adb shell input keyevent 223
若是锁屏没有密码,是经过滑动手势解锁,那么能够经过 input swipe
来解锁。
命令(参数以机型 Nexus 5,向上滑动手势解锁举例)
adb shell input swipe 300 1000 300 500
参数 300 1000 300 500
分别表示起始点x坐标 起始点y坐标 结束点x坐标 结束点y坐标
。
在焦点处于某文本框时,能够经过 input
命令来输入文本。
adb shell input text hello
Android 系统的日志分为两部分,底层的 Linux 内核日志输出到 /proc/kmsg,Android 的日志输出到 /dev/log。
[adb] logcat [<option>] ... [<filter-spec>] ...
经常使用用法列举以下:
Android 的日志分为以下几个优先级(priority):
V —— Verbose(最低,输出得最多)
D —— Debug
I —— Info
W —— Warning
E —— Error
F —— Fatal
S —— Silent(最高,啥也不输出)
按某级别过滤日志则会将该级别及以上的日志输出。
示例:
adb logcat *:W
会将 Warning、Error、Fatal 和 Silent 日志输出。
(注:在 macOS 下须要给 *:W
这样以 *
做为 tag 的参数加双引号,如 adb logcat "*:W"
,否则会报错 no matches found: *:W
。)
按 tag 和级别过滤日志
<filter-spec>
能够由多个 <tag>[:priority]
组成。
好比,命令:
adb logcat ActivityManager:I MyApp:D *:S
表示输出 tag ActivityManager
的 Info 以上级别日志,输出 tag MyApp
的 Debug 以上级别日志,及其它 tag 的 Silent 级别日志(即屏蔽其它 tag 日志)。
清空日志
adb logcat -c
adb shell dmesg
<6>[14201.684016] PM: noirq resume of devices complete after 0.982 msecs <6>[14201.685525] PM: early resume of devices complete after 0.838 msecs <6>[14201.753642] PM: resume of devices complete after 68.106 msecs <4>[14201.755954] Restarting tasks ... done. <6>[14201.771229] PM: suspend exit 2016-08-28 13:31:32.679217193 UTC <6>[14201.872373] PM: suspend entry 2016-08-28 13:31:32.780363596 UTC <6>[14201.872498] PM: Syncing filesystems ... done.
中括号里的 [14201.684016]
表明内核开始启动后的时间,单位为秒。
经过内核日志咱们能够作一些事情,好比衡量内核启动时间,在系统启动完毕后的内核日志里找到 Freeing init memory
那一行前面的时间就是。
adb shell getprop ro.product.model
输出示例:
MI PLAY
adb shell dumpsys battery
输出示例:
Current Battery Service state: AC powered: false USB powered: true Wireless powered: false Max charging current: 500000 Max charging voltage: 5000000 Charge counter: 92 status: 2 health: 2 present: true level: 99 scale: 100 voltage: 4304 temperature: 300 technology: Li-poly
其中 scale
表明最大电量,level
表明当前电量。上面的输出表示还剩下 99% 的电量。
adb shell wm size
输出示例:
Physical size: 1080x2280
该设备屏幕分辨率为 1080px * 2280px。
若是使用命令修改过,那输出多是:
Physical size: 1080x1920 Override size: 480x1024
代表设备的屏幕分辨率本来是 1080px * 1920px,当前被修改成 480px * 1024px。
25)屏幕密度
adb shell wm density
输出示例:
Physical density: 480 Override density: 440
表面该屏幕是480dpi, 当前被修改成440dpi
adb shell dumpsys window displays
输出示例:
WINDOW MANAGER DISPLAY CONTENTS (dumpsys window displays) Display: mDisplayId=0 init=1080x1920 420dpi cur=1080x1920 app=1080x1794 rng=1080x1017-1810x1731 deferred=false layoutNeeded=false
其中 mDisplayId
为 显示屏编号,init
是初始分辨率和屏幕密度,app
的高度比 init
里的要小,表示屏幕底部有虚拟按键,高度为 1920 - 1794 = 126px 合 42dp。
adb shell settings get secure android_id
输出示例:
400e7cbc54f5cf60
在 Android 4.4 及如下版本可经过以下命令获取 IMEI:
adb shell dumpsys iphonesubinfo
输出示例:
Phone Subscriber Info: Phone Type = GSM Device ID = 860955027785041
其中的 Device ID
就是 IMEI。
而在 Android 5.0 及以上版本里这个命令输出为空,得经过其它方式获取了(须要 root 权限):
adb shell su service call iphonesubinfo 1
输出示例:
Result: Parcel( 0x00000000: 00000000 0000000f 00360038 00390030 '........8.6.0.9.' 0x00000010: 00350035 00320030 00370037 00350038 '5.5.0.2.7.7.8.5.' 0x00000020: 00340030 00000031 '0.4.1... ')
把里面的有效内容提取出来就是 IMEI 了,好比这里的是 860955027785041
。
参考:adb shell dumpsys iphonesubinfo not working since Android 5.0 Lollipop
29)Android系统版本
adb shell getprop ro.build.version.release
输出示例:
8.1.0
adb shell ifconfig | grep Mask
输出示例:
inet addr:10.130.245.230 Mask:255.255.255.252 inet addr:127.0.0.1 Mask:255.0.0.0
那么 10.130.245.230
就是设备 IP 地址。
在有的设备上这个命令没有输出,若是设备连着 WiFi,可使用以下命令来查看局域网 IP:
adb shell ifconfig wlan0
输出示例:
wlan0: ip 10.129.160.99 mask 255.255.240.0 flags [up broadcast running multicast]
或
wlan0 Link encap:UNSPEC inet addr:10.129.168.57 Bcast:10.129.175.255 Mask:255.255.240.0 inet6 addr: fe80::66cc:2eff:fe68:b6b6/64 Scope: Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:496520 errors:0 dropped:0 overruns:0 frame:0 TX packets:68215 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:3000 RX bytes:116266821 TX bytes:8311736
若是以上命令仍然不能获得指望的信息,那能够试试如下命令(部分系统版本里可用):
adb shell netcfg
输出示例:
wlan0 UP 10.129.160.99/20 0x00001043 f8:a9:d0:17:42:4d lo UP 127.0.0.1/8 0x00000049 00:00:00:00:00:00 p2p0 UP 0.0.0.0/0 0x00001003 fa:a9:d0:17:42:4d sit0 DOWN 0.0.0.0/0 0x00000080 00:00:00:00:00:00 rmnet0 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rmnet1 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rmnet3 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rmnet2 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rmnet4 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rmnet6 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rmnet5 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rmnet7 DOWN 0.0.0.0/0 0x00000000 00:00:00:00:00:00 rev_rmnet3 DOWN 0.0.0.0/0 0x00001002 4e:b7:e4:2e:17:58 rev_rmnet2 DOWN 0.0.0.0/0 0x00001002 4e:f0:c8:bf:7a:cf rev_rmnet4 DOWN 0.0.0.0/0 0x00001002 a6:c0:3b:6b:c4:1f rev_rmnet6 DOWN 0.0.0.0/0 0x00001002 66:bb:5d:64:2e:e9 rev_rmnet5 DOWN 0.0.0.0/0 0x00001002 0e:1b:eb:b9:23:a0 rev_rmnet7 DOWN 0.0.0.0/0 0x00001002 7a:d9:f6:81:40:5a rev_rmnet8 DOWN 0.0.0.0/0 0x00001002 4e:e2:a9:bb:d0:1b rev_rmnet0 DOWN 0.0.0.0/0 0x00001002 fe:65:d0:ca:82:a9 rev_rmnet1 DOWN 0.0.0.0/0 0x00001002 da:d8:e8:4f:2e:fe
能够看到网络链接名称、启用状态、IP 地址和 Mac 地址等信息。
adb shell cat /sys/class/net/wlan0/address
输出示例:
f8:a9:d0:17:42:4d
这查看的是局域网 Mac 地址,移动网络或其它链接的信息能够经过前面的小节「IP 地址」里提到的 adb shell netcfg
命令来查看。
adb shell cat /proc/cpuinfo
输出示例:
Processor : ARMv7 Processor rev 0 (v7l) processor : 0 BogoMIPS : 38.40 processor : 1 BogoMIPS : 38.40 processor : 2 BogoMIPS : 38.40 processor : 3 BogoMIPS : 38.40 Features : swp half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt CPU implementer : 0x51 CPU architecture: 7 CPU variant : 0x2 CPU part : 0x06f CPU revision : 0 Hardware : Qualcomm MSM 8974 HAMMERHEAD (Flattened Device Tree) Revision : 000b Serial : 0000000000000000
这是 Nexus 5 的 CPU 信息,咱们从输出里能够看到使用的硬件是 Qualcomm MSM 8974
,processor 的编号是 0 到 3,因此它是四核的,采用的架构是 ARMv7 Processor rev 0 (v71)
。
adb shell cat /proc/meminfo
输出示例:
MemTotal: 3797876 kB MemFree: 207828 kB MemAvailable: 1713920 kB
其中,MemTotal
就是设备的总内存,MemFree
是当前空闲内存。
adb reboot
adb shell wm size 480x1024
表示将分辨率修改成 480px * 1024px。
adb shell wm size reset
adb shell wm density 160
标识将屏幕修改成160dpi
adb shell wm density reset
adb shell wm overscan 0,0,0,200
四个数字分别表示距离左、上、右、下边缘的留白像素,以上命令表示将屏幕底部 200px 留白。
adb shell wm overscan reset
adb shell settings put global adb_enabled 0
用命令恢复不了了,毕竟关闭了 USB 调试 adb 就链接不上 Android 设备了。
去设备上手动恢复吧:「设置」-「开发者选项」-「Android 调试」。
adb shell settings put global policy_control <key-values>
<key-values>
可由以下几种键及其对应的值组成,格式为 <key1>=<value1>:<key2>=<value2>
例如:
adb shell settings put global policy_control immersive.full=*
表示设置在全部界面下都同时隐藏状态栏和导航栏。
adb shell settings put global policy_control immersive.status=com.package1,com.package2:immersive.navigation=apps,-com.package3
表示设置在包名为 com.package1
和 com.package2
的应用里隐藏状态栏,在除了包名为 com.package3
的全部应用里隐藏导航栏。
adb shell screencap -p /sdcard/sc.png
而后将 png 文件导出到电脑:
adb pull /sdcard/sc.png
可使用 adb shell screencap -h
查看 screencap
命令的帮助信息,下面是两个有意义的参数及含义:
实测若是指定文件名以 .png
结尾时能够省略 -p 参数;不然须要使用 -p 参数。若是不指定文件名,截图文件的内容将直接输出到 stdout。
直接一行命令截图并保存到电脑的方法:
Linux 和 Windows
adb shell screencap -p | sed "s/\r$//" > sc.png
Mac OS X
adb shell screencap -p | gsed "s/\r$//" > sc.png
这个方法须要用到 gnu sed 命令,在 Linux 下直接就有,在 Windows 下 Git 安装目录的 bin 文件夹下也有。若是确实找不到该命令,能够下载 sed for Windows 并将 sed.exe 所在文件夹添加到 PATH 环境变量里。
而在 Mac 下使用系统自带的 sed 命令会报错:
sed: RE error: illegal byte sequence
须要安装 gnu-sed,而后使用 gsed 命令:
brew install gnu-sed
录制屏幕以 mp4 格式保存到 /sdcard:
adb shell screenrecord /sdcard/filename.mp4
须要中止时按 Ctrl-C,默认录制时间和最长录制时间都是 180 秒。
若是须要导出到电脑:
adb pull /sdcard/filename.mp4
可使用 adb shell screenrecord --help
查看 screenrecord
命令的帮助信息,下面是常见参数及含义:
注:须要 root 权限。
/system 分区默认挂载为只读,但有些操做好比给 Android 系统添加命令、删除自带应用等须要对 /system 进行写操做,因此须要从新挂载它为可读写。
步骤:
#1. 进入 shell 并切换到 root 用户权限。
命令:
adb shell
su
#2.查看当前分区挂载状况
命令:
mount
输出示例
输出示例: rootfs / rootfs ro,relatime 0 0 tmpfs /dev tmpfs rw,seclabel,nosuid,relatime,mode=755 0 0 devpts /dev/pts devpts rw,seclabel,relatime,mode=600 0 0 proc /proc proc rw,relatime 0 0 sysfs /sys sysfs rw,seclabel,relatime 0 0 selinuxfs /sys/fs/selinux selinuxfs rw,relatime 0 0 debugfs /sys/kernel/debug debugfs rw,relatime 0 0 none /var tmpfs rw,seclabel,relatime,mode=770,gid=1000 0 0 none /acct cgroup rw,relatime,cpuacct 0 0 none /sys/fs/cgroup tmpfs rw,seclabel,relatime,mode=750,gid=1000 0 0 none /sys/fs/cgroup/memory cgroup rw,relatime,memory 0 0 tmpfs /mnt/asec tmpfs rw,seclabel,relatime,mode=755,gid=1000 0 0 tmpfs /mnt/obb tmpfs rw,seclabel,relatime,mode=755,gid=1000 0 0 none /dev/memcg cgroup rw,relatime,memory 0 0 none /dev/cpuctl cgroup rw,relatime,cpu 0 0 none /sys/fs/cgroup tmpfs rw,seclabel,relatime,mode=750,gid=1000 0 0 none /sys/fs/cgroup/memory cgroup rw,relatime,memory 0 0 none /sys/fs/cgroup/freezer cgroup rw,relatime,freezer 0 0 /dev/block/platform/msm_sdcc.1/by-name/system /system ext4 ro,seclabel,relatime,data=ordered 0 0 /dev/block/platform/msm_sdcc.1/by-name/userdata /data ext4 rw,seclabel,nosuid,nodev,relatime,noauto_da_alloc,data=ordered 0 0 /dev/block/platform/msm_sdcc.1/by-name/cache /cache ext4 rw,seclabel,nosuid,nodev,relatime,data=ordered 0 0 /dev/block/platform/msm_sdcc.1/by-name/persist /persist ext4 rw,seclabel,nosuid,nodev,relatime,data=ordered 0 0 /dev/block/platform/msm_sdcc.1/by-name/modem /firmware vfat ro,context=u:object_r:firmware_file:s0,relatime,uid=1000,gid=1000,fmask=0337,dmask=0227,codepage=cp437,iocharset=iso8859-1,shortname=lower,errors=remount-ro 0 0 /dev/fuse /mnt/shell/emulated fuse rw,nosuid,nodev,relatime,user_id=1023,group_id=1023,default_permissions,allow_other 0 0 /dev/fuse /mnt/shell/emulated/0 fuse rw,nosuid,nodev,relatime,user_id=1023,group_id=1023,default_permissions,allow_other 0 0
找到其中咱们关注的带 /system 的那一行:
/dev/block/platform/msm_sdcc.1/by-name/system /system ext4 ro,seclabel,relatime,data=ordered 0 0
#3.从新挂载
命令:
mount -o remount,rw -t yaffs2 /dev/block/platform/msm_sdcc.1/by-name/system /system
这里的 /dev/block/platform/msm_sdcc.1/by-name/system
就是咱们从上一步的输出里获得的文件路径。
若是输出没有提示错误的话,操做就成功了,能够对 /system 下的文件随心所欲了。
注:须要 root 权限。
adb shell su cat /data/misc/wifi/*.conf
输出示例:
network={ ssid="TP-LINK_9DFC" scan_ssid=1 psk="123456789" key_mgmt=WPA-PSK group=CCMP TKIP auth_alg=OPEN sim_num=1 priority=13893 }
ssid
即为咱们在 WLAN 设置里看到的名称,psk
为密码,key_mgmt
为安全加密方式。
注:须要 root 权限。
adb shell su date -s 20160823.131500
表示将系统日期和时间更改成 2016 年 08 月 23 日 13 点 15 分 00 秒。
adb reboot
adb shell
su
此时命令行提示符是 $
则表示没有 root 权限,是 #
则表示已 root。
Monkey 能够生成伪随机用户事件来模拟单击、触摸、手势等操做,能够对正在开发中的程序进行随机压力测试。
简单用法:
adb shell monkey -p <packagename> -v 500
表示向 <packagename>
指定的应用程序发送 500 个伪随机事件。
Monkey 的详细用法参考 官方文档。
注:须要 root 权限。
有时须要控制设备的 WiFi 状态,能够用如下指令完成。
开启 WiFi:
adb root
adb shell svc wifi enable
关闭WiFi
adb root
adb shell svc wifi disable
若执行成功,输出为空;若未取得 root 权限执行此命令,将执行失败,输出 Killed
。
下面是刷机相关的命令
adb reboot recovery
adb reboot
adb reboot bootloader
若是咱们下载了 Android 设备对应的系统更新包到电脑上,那么也能够经过 adb 来完成更新。
以 Recovery 模式下更新为例:
#1.重启到Recovery模式
adb reboot recovery
#2.在设备的 Recovery 界面上操做进入 Apply update
-Apply from ADB
。
注:不一样的 Recovery 菜单可能与此有差别,有的是一级菜单就有 Apply update from ADB
。
#3.经过 adb 上传和更新系统
adb sideload <path-to-update.zip>
最后
Android 系统是基于 Linux 内核的,因此 Linux 里的不少命令在 Android 里也有相同或相似的实现,在 adb shell
里能够调用。