Adb 命令

来源:互联网 发布:为知笔记 archlinux 编辑:程序博客网 时间:2024/05/19 14:37

adb简介

adb的全称为Android Debug Bridge,就是起到调试桥的作用。通过adb我们可以在Eclipse中方便通过DDMS来调试Android程序,说白了就是debug工具。adb的工作方式比较特殊,采用监听Socket TCP 5554等端口的方式让IDE和Qemu通讯,默认情况下adb会daemon相关的网络端口,所以当我们运行Eclipse时adb进程就会自动运行。
adb是android sdk里的一个工具, 用这个工具可以直接操作管理android模拟器或者真实的andriod设备(如G1手机).  它的主要功能有:
* 运行设备的shell(命令行)
* 管理模拟器或设备的端口映射
* 计算机和设备之间上传/下载文件
* 将本地apk软件安装至模拟器或android设备


ADB是一个 客户端-服务器端 程序, 其中客户端是你用来操作的电脑, 服务器端是android设备.
ADB(Android Debug Bridge)用来做下面两件事:
- 跟踪所有已连接的Android设备或运行在开发者机器上的模拟器实例。
- 为满足客户端的需求实现丰富的控制命令。客户端包括命令行用户或者像DDMS一样的帮助程序,控制命令包括“adb shell”,“adb pull”等等。这些控制命令在ADB中被称作“服务”。

总体来看,ADB中的每项工作通过下列组件的配合完成:
1. ADB服务器
ADB服务器是运行在主机上的一个后台进程。它的作用在于检测USB端口感知设备的连接和拔除,以及模拟器实例的启动或停止。
ADB服务器维护了一个已连接设备的列表,并且为每一个连接设备分配一个状态值,状态值包括:OFFLINE、BOOTLOADER、RECOVERY、ONLINE。
ADB服务器实际上是一个庞大的多路传输循环,它精妙的协调客户端、服务与设备之间的数据交换(实际上是包交换)。
2. ADB守护进程(adbd)
程序“adbd”作为一个后台进程在Android设备或模拟器系统中运行。它的作用是连接ADB服务器(通过USB连接设备,通过TCP连接模拟器),并且为运行在主机上的客户端提供一些服务。
当ADB服务器成功的与一个设备上的adbd守护进程建立连接时,ADB服务器认为这个设备是“ONLINE”状态。否则,ADB服务器认为设备是“OFFLINE”状态,“OFFLINE”表明ADB服务器侦测到一个新的设备或模拟器,但是无法与该设备或模拟器上的adbd守护进程建立连接。
“BOOTLOADER”状态表明设备处于bootloader模式下,“RECOVERY”状态表明设备处于recovery模式下。
3. ADB命令行客户端
命令行程序“adb”用于从shell或脚本中运行adb命令。首先,“adb”程序尝试定位主机上的ADB服务器,如果找不到ADB服务器,“adb”程序自动启动一个ADB服务器。
接下来,客户端向ADB服务器发送服务请求。这里面的细节不需要了解。
通常,一个单一的“adb” 二进制程序文件包含了服务器和客户端的实现。这样,服务器的分发和启动都更加容易。
4. 服务
与客户端交互的服务有两种:
主机服务:
主机服务运行在ADB服务器中,因此它们根本不和设备通讯。一个典型的例子就是“adb devices”,它请求返回当前已知的设备及其状态的列表。
本地服务:
本地服务运行在adbd守护进程中,或者被设备上的adbd守护进程启动。ADB服务器被用于客户端与本地服务之间的多路传输数据流。在这种情况下,本地服务的任务是初始化连接,然后为ADB服务器提供服务响应数据。


adb所用的协议


1.客户端<->服务器 交互协议
下面详细说明ADB客户端和ADB服务器之间交互的协议。ADB服务器监听在TCP:localhost:5037。
客户端用下列格式发送请求:
A. 开头4个字节的十六进制字符串给出请求的长度;
B. 后面紧跟请求内容。
举例来说,为了获得ADB服务器的内部版本号,客户端将做下列工作:
A. 建立tcp:localhost:5037的socket连接;
B. 通过socket发送字符串“000Chost:version”。
前缀“host:”用来指示请求被定位到ADB服务器本身(稍后我们将讨论其他类型的请求)。为了便于调试排错,请求内容的长度按ASCII编码计算。

服务器用下列格式回应客户端请求:
A. 成功:回应4个字节的“OKAY”字符串;
B. 失败:回应4个字节的“FAIL”字符串 + 4个字节的十六进制长度说明 + 指定长度的字符串说明失败原因;
C. “host:version”是一个例外,它的回应是4个字节的十六进制字符串,说明服务器的内部版本号。
注意:回应“OKAY”之后,连接仍然是活动的,这样,客户端可以通过这个连接发送其他的请求。但是在特定的情况下,“OKAY”回应会改变连接的状态。
举例来说,客户端发出“host:transport:”请求,“”被用来标识一个指定的设备或模拟器;在服务器回应“OKAY”之后,客户端再发起的请求会直接送达至对应的adbd守护进程。
在以后的文章中,SSW会列举当前ADB实现的所有服务。

2.传输协议
ADB传输协议对ADB服务器与一个设备或模拟器之间的连接进行建模。当前有两种类型的传输协议:
- USB传输协议,用于通过USB与物理设备的连接。
- 本地传输协议,用于通过TCP连接到ADB服务器,运行在主机上的模拟器。
虽然现在还没有实现,但是理论上存在这样的可能:写一个本地传输协议,让它代理ADB服务器与连接到另一台机器的设备之间的连接,以及ADB服务器与运行在另一台机器上的模拟器之间的连接。
每次传输能够在客户端和它们所指向的设备或模拟器之间完成一个或多个多路复用数据流。ADB服务器必须正确处理意料之外的传输中断。(比如:设备被物理拔除)


常用的adb命令
①查看应用程序的详细信息(包名+版本号,名称+sdk版本+权限+启动图标)
aapt d badging 电脑apk路径
注意:这里需要配置aapt命令到path路径中
②启动应用
adb shell am start -n com.example.test/com.example.test.TestActivity
注意:com.example.test.TestActivity为初始类全名
③安装应用
adb install [ -r 强制覆盖安装] [-f 安装到手机内存 /data/app目录] [-s 安装sdcard/sdcard目录] apk 路径 ;
注意:默认是安装到手机内存的,当安装到手机内存时,因不能直接操作/data/app目录,需要先把apk存放到一个临时目录(adb push apkpath /data/local/tmp/apkname),然后,在底层调用命令(pm install /data/local/tmp/apkname),执行安装操作。而安装到sd卡上,是可以直接操作的,不需要存放到临时目录中。
④卸载应用
adb uninstall 包名
pm uninstall [ -k 删除应用,保持应用的数据] 包名
注意:pm指令需要执行adb shell后,执行
⑤从电脑推送文件到手机
adb push <电脑文件路径> <手机目标路径>
⑥从手机导出文件到电脑
adb pull <手机源文件路径> <电脑文件路径>
⑦ adb shell dumpsys cpuinfo |notification| meminfo |cpuinfo
查看手机当前的cpu使用 notification使用 meminfo


pm指令
①pm install [-r强制安装] [-f手机内存] [-s安装到sd卡] apkname;
②pm uninstall [-k保存] packname;
③pm clear packname ——清除应用的缓存数据
④pm disable packname —-冻结应用,需要root权限
⑤pm enable packname —-解冻应用,需要root权限
⑥pm path packname —-列出应用的安装路径

Linux指令
① ls -l
列出目录下所有文件的详细信息 *

注意:busybox—–linux下的工具盒,linux下的可执行程序,里面封装很多指令(几乎所有system/bin目录下的可执行程序)。—Android系统下/system/bin/目录下的都是这样的一些可执行程序—-cp\cat\mkdir等等

② df 查看磁盘空间
③ mount 产看磁盘信息
④ rm apkname 删除文件 eg: rm /data/local/tmp/1.apk
rm -r 删除文件夹
mv 移动文件、重命名文件 mv /data/local/tmp/1.apk /data/local/tmp/2.apk
⑤ mount -o remountn rw /system 挂载分区/system为可读可写

⑥ mkdir 创建文件夹
mkdir -p path 创建多级文件
⑦ echo “11” > /sdcard/a.txt; —- 创建文件a.txt 并写入 “11”
⑧ cat path 查看文件内容; cat /proc/cpuinfo
cat path1 > path2 将 path1复制一份
cat /data/local/tmp/1.apk > /sdcard/1.apk
9. cp path1 path2 复制文件
cp /data/local/tmp/1.apk /sdcard/1.apk
10. touch “filepath” 创建一个空文件 touch /data/local/tmp/1.apk
11. chmod 777 filepath ; 为文件或目录赋权限 chmod 777 /data/local/tmp/1.apk
12. chown 0.0 filepath 赋所属用户及用户组 chmod 0.0 /data/local/tmp/1.apk —root权限
13. ps 查看当前系统所有进程,相当于任务管理器
14. sleep 5; 进程睡眠多少秒,这里不是以毫秒为单位
15. kill 杀进程
16. md5sum /md5命令 获取文件的MD5码 eg: md5sum /system/app/1.apk
17. halt 关机 reboot 重启 不是所有手机都支持


linux文件组

Android下用户分类:
root用户: uid 0 gid0
system用户: uid 1000 gid1000
shell用户: uid 2000 gid2000
app用户: uid >10000 gid >10000

如上图所示: 一个用户有且只用一个所属的群组,可以有多个所属的附加群组。
chmod命令可以设置文件的权限;
注意:我们可以通过数字或符号设置权限;
如果是数字,则4代表r,2代表w,1代表x,如果是5代表r-x,6代表rw-,7代表rwx;
如果是符号,则a代表全部人,u代表owner,g代表group,o代表others,r就是r,w就是w,x就是x,什么都不写表示一个权限都没有;
(1)chmod 755 test.txt:赋予test.txt rwxr-xr-x
(2)chmod u=rwx,go=r test.txt:赋予test.txt rwxr–r–
(3)chmod a=r test.txt:赋予test.txt r–r–r–
(4)chmod a+x test.txt:给test.txt全部的人添加x权限;
(5)chmod a-x test.txt:给test.txt全部的人删除x权限;
(6)chmod u=rwx,go= test.txt:赋予test.txt rwx——

whoami —–查看当前用户的权限
id —- (获取当前用户信息) 查看uid\gid\groups的信息
su —–变成root用户

———-sqilite命令
①找到应用程序数据库,sqlite3 test.db进入Android数据库,运用sql语句查询,但不支持中文

②当列之间非常紧密,想将列之间的空隙变大一些,使用命令 . mode column

③显示数据库中所有表的名称—.tables

*使用having 子句 对分组结果进行过滤
having和where都可以进行过滤,但是where是在分组之前进行过滤,having在分组之后进行过滤.having子句中可以使用聚合函数而where子句中不能使用聚合函数

!!sql语句的书写顺序,执行顺序
书写顺序:select from where group by having order by
~~查询单价小于100总价大于150的商品降序排列
select product from orders where price < 100 group by product having sum(price)>150 order by product desc;(降序)asc升序
执行顺序:from where select group by having order by

0 0
原创粉丝点击