1,通过adb 连接(WiFi连接或者数据线连接)Android设备

2,PC端进入命令窗口(win +R 组合键后,输入cmd)

3,adb shell 进入linux命令行,#代表已经root了,$代表没有root权限;

4,获取root权限:执行su root 即可获取root权限(一般的 Android板子 可以这样获取root权限,手机一般这样是不行的),有些厂家的板子重启之后root权限会消失,需要的时候需重新执行su root 命令获取root权限;

5,获取Root权限有些板子是执行 adb root

其他常用adb指令:

1.adb install +包名       adb安装apk (覆盖安装是使用 -r 选项)

2.adb uninstall +包名      adb卸载apk

3.adb connect +设备IP      网络连接Android设备

4.adb reboot       重启Android设备

5.adb devices      获取连接的设备列表及设备状态

6.adb get-state    获取设备的状态 (设备的状态有 3 钟, device: 设备正常连接 , offline: 连接出现异常,设备无响应 , unknown: 没有连接设备)

7.查看运行在 Android设备上的 adb 后台进程:

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

8.adb shell 命令

adb 命令是 adb 这个程序自带的一些命令,而 adb shell 则是调用的 Android 系统中的命令,这些 Android 特有的命令都放在了 Android 设备的 system/bin 目录下

8.1. adb shell  bugreport , 打印 dumpsys 、dumpstate、logcat的输出,也是用于分析错误

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

adb shell dumpsys > D:\bugreport.log

8.2 pm
Package Manager , 可以用获取到一些安装在 Android 设备上得应用信息

8.2.1  adb shell pm list package      列出所有的应用的包名 (-s:列出系统应用  -3:列出第三方应用 -f:列出应用包名及对应的apk名及存放位置  -i:列出应用包名及其安装来源)

8.2.2  adb shell pm path+包名     列出对应包名.apk 位置

8.2.3  adb shell pm install +apk存放路径   安装应用(目标 apk 存放于PC端,用 adb install 安装   目标 apk 存放于Android设备上,用 pm install 安装)

8.2.4 adb shell pm clear com.google.android.inputmethod.pinyin  清除应用数据

8.3 am

8.3.1 adb shell  am start +包名/.Activity (要启动的Activity)     启动一个 Activity (-s先停止目标应用,再启动  -w 等待应用完成启动  -a 启动默认浏览器打开一个网页例:adb shell am start -a android.intent.action.VIEW -d http://testerhome.com)

8.3.2  adb shell am monitor        监控 crash 与 ANR

8.3.3  adb shell am force-stop    后跟包名,结束应用

8.3.4  adb shell am startservice    启动一个服务

8.3.5  adb shell am broadcast       发送一个广播

8.4 input

这个命令可以向 Android 设备发送按键事件

8.4.1 adb shell input text +具体内容    发送文本内容,不能发送中文

8.4.2 adb shell input keyevent + 按键事件   发送按键事件 例如:adb shell input keyevent KEYCODE_HOME 模拟按下Home键

8.4.3 adb shell input tap +触摸事件的位置 , 对屏幕发送一个触摸事件 例如:点击屏幕上坐标为 500 500 的位置(adb shell input tap 500 500)

8.4.4 adb shell input tap , 对屏幕发送一个触摸事件

8.4.4 adb shell input swipe   滑动事件  例如:从右往左滑动屏幕

adb shell input swipe 800 600 100 600

8.5 screencap

adb shell screencap -p /sdcard/DCIM/screenTest.png

8.6 screenrecord

4.4以上系统版本新增的录制命令

adb shell screenrecord /sdcard/demo.mp4

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

8.7 ime

列出设备上的输入法

adb shell ime list -s

1.获取系统版本

adb shell getprop ro.build.version.release

2.获取系统api版本

adb shell getprop ro.build.version.sdk

3.获取手机相关制造商信息

adb shell getprop | grep "model\|version.sdk\|manufacture
r\|hardware\|platform\|revision\|serialno\|product.name\|brand"

3,获取手机系统信息( CPU,厂商名称等)

adb shell "cat /system/build.prop | grep "product""

4,获取手机设备型号

adb -d shell getprop ro.product.model

5,获取手机厂商名称

adb -d shell getprop ro.product.brand

6,获取手机的序列号

有两种方式

1,adb get-serialno
2,adb shell getprop ro.serialno

7,获取手机MAC地址

adb shell cat /sys/class/net/wlan0/address

8,获取手机内存信息

adb shell cat /proc/meminfo

9,获取手机存储信息

adb shell df

10,获取手机内部存储信息

adb shell df /data

11,获取Android设备屏幕分辨率

adb shell "dumpsys window | grep mUnrestrictedScreen"

12,连接多个设备对其中一个进行操作
//以adb shell 为例
adb -s 192.168.101.37:5555 shell

13,查看运行进程

adb shell procrank

14,关闭或杀掉进程

adb shell kill 366

15,保留数据和缓存文件,重新安装,升级

adb install -r test.apk

16,卸载app但保留数据和缓存文件

adb uninstall -k cnblogs.apk

17,查看目录下的文件大小

adb shell du -sh *

18,查看正在运行的Services

adb shell dumpsys activity services [<packagename>]

19,查看正在运行的Activity

adb shell dumpsys activity [<packagename>]

20,clear 清除应用数据

adb shell pm clear com.baidu

21,cp复制文件

adb shell 进入Android Linux命令中

cp -f system/app/Music/Music.apk /sdcard/Music.apk

22,删除命令

adb shell 进入Android Linux命令中

rm  -r  /mnt/sdcard/a.mp3

删除文件夹的时候需要加上-r参数

cd dir
rm *    删除dir中所有文件

23,重启进入recovery模式

adb reboot recovery

24,cat查看文件

cat  /sdcard/test.txt

25,查看指定进程PID

ps +  进程的包名

26,查看进程具体的信息

例如:1460是要查看的进程的PID
cat /proc/1460/maps    查看进程的文件结构
cat /proc/1460/status   查看进程的状态

27,findstr 和 grep过滤搜索

1)cmd下搜索包名为com.android.launcher3的进程
adb shell ps|findstr /i “com.android.launcher3”

2)shell下面搜索
先使用adb shell进去,然后使用grep命令过滤
ps | grep “com.linux.test”

adb root 权限是在system/core/ adb / adb .c 中控制。主要根据ro.secure 以及 ro.debuggable 等system property 来控制。 默认即档ro.secure 为0 时,即开启 root 权限,为1时再根据ro.debuggable 等选项来确认 是否 可以用开启 root 权限。为此如果要永久性开启 adb root 权限,有两种修改的方式: 1. 修改system property ro.secure, 让ro.secure=0。 2. 修改 adb .c 中开启 root 权限的判断逻辑。 下面详细说明这两种修改方式: 第一种方法. 修改syst C:\signapp&gt; adb root restarting adb d as root # 说明有 root权限 ,若是 adb d cannot run as root in production builds 则说明没有 root权限 二、更改system/app内容 一般情况下system/app都会出现read ... android root权限 破解分析 许多机友新购来的 Android 机器没有破解过 Root权限 ,无法使用一些需要高权限的软件,以及进行一些高权限的操作,其实破解手机 Root权限 是比较简单及安全的,破解 Root权限 的原理就是在手机的/system/bin/或/system/xbin/目录下放置一个可执行文件“su”,这是一个二进制文件,相当于电脑上的exe文件,仅仅在系统中置入这个“su”文件是不会给手机的软件或硬件造成任何故障。 下面的代码是 android 系统原版的su中的部分代码,可以看出只允许getuid()为AID_ ROOT 和AID_SHELL的进程可以使用su进行登陆。 代码如下:<S 3, adb push C:\Users\Administrator\Desktop\test.jpg sdcard 注:C:\Users\Administrator\Desktop\test.jpg是... ro.sf.lcd_density属性指定了这个机型使用的dpi是多少,dpi全称是dots per inch,对角线每英寸的像素点的个数。 adb 查看 屏幕分辨率、基准比例。 注意window中直接输入可能会出现log文件打开显示乱码问题;项目执行后就可以在D盘打开logcat文件,里边就是需要的日志;保存tag标签的log到D:\logcat.log 文件。则 执行 chcp 65001。 查看 结果 如果不是65001。 一、 ADB 是什么? ADB ,即 Android Debug Bridge 是一种允许模拟器或已连接的 Android 设备进行通信的命令行工具,它可为各种设备操作提供便利,如安装和调试应用,并提供对 Unix shell(可用来在模拟器或连接的设备上运行各种命令)的访问。可以在 Android SDK/platform-tools中找到 adb 工具或下载 ADB Kits 。 注: 有部分命令的...