安卓调试桥(Android Debug Bridge),是Android SDK中的一个调试工具, 使用adb可以直接 *** 作管理Android模拟器或Andriod真机设备,在开发测试过程中,起到调试的作用。
adbexe的存放路径:Android-SDKplatform-tools
adb help //查看帮助
adb version //查看adb版本号
adb devices //查看设备
adb connect IP:port //连接设备
adb disconnect //断开连接的所有设备
adb disconnect IP:port //断开连接指定设备
adb root //获取root权限
adb remount //重新挂载文件系统(默认只读,执行命令后可写)
adb install Package //安装APK
adb install -r Package //强制覆盖安装
adb install -t Package //允许降级覆盖安装
adb install -d Package //允许测试包
adb uninstall PackageName //卸载APK
adb uninstall -k (keep) PackageName //保留用户数据卸载
adb pull //将设备文件文件发送到PC
adb push //将PC文件发送到设备
adb logcat -c //清空日志
adb logcat -v threadtime >D:111log //抓日志并输出保存D:111log
adb shell screencap /sdcard/screenpng //屏幕截图(并存放sdcard目录,命名screenpng)
adb shell screenrecord /sdcard/demomp4 //录制屏幕(Android44以上可用)
adb shell dumpsys activity activities //查看activity信息
adb shell dumpsys activity |findstr mResumedActivity //获取当前activity信息
adb shell dumpsys window windows | findstr “Current” //查看当前app窗口activity
adb shell //进入设备内部
cd //切换目录
pwd //查看当前路径
ping //查看网络连接
rm //删除目录下的所有文件
cp -r /path/filename /NewPath //拷贝文件
busybox find / -name FileName //查找文件
tcpdump -i any -p -s 0 -w /data/data/1111pcap //抓取网络包
pm uninstall PackageName //卸载APK
pm path PackageName //查看APK存放位置
pm clear PackageName //清除APK缓存
dumpsys package omandroidxxx //查看APK的具体信息
dumpsys package omandroidxxx | grep version //查看APK版本
dumpsys package comtencentmm | findstr versionName //查看APK版本
am start PackageName //拉起APK
am start -n comandroidxxx/WelcomeActivity //直接拉起APK的指定WelcomeActivity
am start -a androidintentactionVIEW -d >
很早就想整理一下自己平时常用的一些adb命令,不仅为了便于以后查找,而且整理的过程自己又重新复习了一遍,但是当我开始在度娘一搜的时候,发现很多人已经写的非常详细了,尤其是当我发现了这篇adb概括
心中一句NND,怎么可以写的这么详细,瞬间没了想写这篇文章的欲望,如果你点了链接发现确实很全,那么恭喜你可以关掉这篇了,哈哈哈。
我就不这么想的,虽然很全,但不是我常用的,因人而异,所以我就权当记笔记+替这哥们宣传了。
– adb devices , 获取设备列表及设备状态
设备的状态有 3 种
device , 设备连接正常
offline , 设备离线,连接出现异常
unauthorized 设备为进行授权,需要在设备上是否允许调试对话框进行授权
offline情况解决办法,先执行adb kill-server 命令,再执行adb start-server 命令,再尝试adb devices 查看列表,如果还是offline,来来来,使用必杀技,重启大法。
当电脑连接多个android设备并可用时,所有的adb命令都需要指定设备后执行(当然你也可以移除多余的设备)
adb -s <设备名称> install/uninstall/shell/pull/push等命令
– adb install app在pc硬盘路径,选中app直接拖入即可
常见的错误情况
INSTALL_FAILED_TEST_ONLY, 安装的app的debug版本的,未签名,adb install -t 路径即可安装
INSTALL_FAILED_DUPLICATE_PACKAGE, 已经安装相同包名的app, 先卸载再安装
– adb uninstall app的包名,卸载app
adb pull 将 Android 设备上的文件或者文件夹复制到本地
adb pull sdcard/Android/111txt E:\
小技巧,可以将本地路径指定为桌面,方便查看, 在桌面按住shift键,鼠标右键选择在此处打开命令行窗口,直接输入adb pull sdcard/Android/111txt 执行,就可将111txt复制到桌面。
前提是设备已经获取root权限
adb root
adb remount
adb push 将pc上文件复制到android设备中,修改room原生应用时比较频繁使用,如settingsapk, launcher3apk
– adb shell pm 命令
adb shell pm list package 列出android设备上的所有app
adb shell pm list package -s 列出android设备上的系统级别app
adb shell pm list package -3 列出android设备上的第三方app(用户安装的)
adb shell pm list package -f 列出app包名及对应的apk名及存放位置
adb shell pm list package -i 列出app包名及其安装来源(应用市场名称)
adb shell pm dump app包名 列出app的相关信息,类似获取Manifest文件内容
-查看前台 Activity
adb shell dumpsys activity activities “| grep mFocusedActivity”
-adb shell am 命令
最常用的就是启动指定的activity和发送指定的广播
启动指定的activity
*** 作指令 adb shell am start -n 包名/类名
注:如果启动activity时,出现如下错误
javalangSecurityException: Permission Denial: starting Intent { flg=0x10000000 > > cmp=commediatekengineermode/ioGpio } from null (pid=3083, uid=2000) not exported from uid 1001
解决办法,1、如果是你自己可控的app,那么找到你要调用的activity在manifestxml中,增加
1
配置即可, android:name="" 可以为空字符串。
2、如果是不可控的app,例如我调用的系统原生app,那么你就洗洗睡吧,别折腾了,除非你修改源码和上边一样 *** 作,重新push替换原来的app。
启动默认浏览器打开一个网页
adb shell am start -a androidintentactionVIEW -d
先停止目标应用,再启动
adb shell am start -s comandroidcamera/Camera
启动相机
adb shell am start -n comandroidcamera/Camera
启动设置
adb shell am start -n comandroidsettings/comandroidsettingsSettings
启动Wifi设置
adb shell am start -n comandroidsettings/comandroidsettingswifiWifiSettings
启动蓝牙设置
adb shell am start -n comandroidsettings/comandroidsettingsbluetoothBluetoothSettings
其它的类似只要你能在manifest中找到配置的,都可以通过这种方法来调用
发送指定的广播
*** 作指令 adb shell am broadcast -a 广播名 --ei/es/ez 参数名 参数值 --ei/es/ez 参数名 参数值
–ei integer 值
–es String 值
–ez boolean 值
–ef float 值
–el long 值
例如之前写的
Android60 源码修改之Setting列表配置项动态添加和静态添加, 当中就通过发送广播来接收增加配置列表项
adb shell am broadcast -a cndynamicaddsettingcategoryitem --es location “0-2” --es title “红” --es intent “comandroidsettingsSCHEDULE_POWER_ON_OFF_SETTING”
-adb shell input keycode 指令
HOME 键 adb shell input keycode 3
返回键 adb shell input keycode 4
打开浏览器 adb shell input keycode 64
-adb shell wm 指令
屏幕分辨率 adb shell wm size
屏幕密度 adb shell wm density
adb shell wm density 320/480/640 可修改屏幕密度查看效果,对应Launcher图标会缩放
adb shell ifconfig 命令
IP 地址 adb shell ifconfig “| grep Mask”
WIFI 地址 adb shell ifconfig wlan0
状态栏和导航栏的显示隐藏
命令:
adb shell settings put global policy_control
可由如下几种键及其对应的值组成,格式为 key1=value1:key2=value2。
key 含义
immersivefull 同时隐藏
immersivestatus 隐藏状态栏
immersivenavigation 隐藏导航栏
immersivepreconfirms 同时显示
这些键对应的值可则如下值用逗号组合:
value 含义
apps 所有应用
所有界面
packagename 指定应用
packagename 排除指定应用
例如:
adb shell settings put global policy_control immersivefull=
表示设置在所有界面下都同时隐藏状态栏和导航栏。(重启也不会失效,恢复需调用下面的命令)
adb shell settings put global policy_control immersivepreconfirms=
表示恢复显示
adb shell settings put global policy_control immersivestatus=compackage1,compackage2:immersivenavigation=apps,-compackage3
表示设置在包名为 compackage1 和 compackage2 的应用里隐藏状态栏,在除了包名为 compackage3 的所有应用里隐藏导航栏
adb shell am force-stop app 关闭APP
adb shell pm clear APP app进程被杀死,且会清楚所有数据
1:查找手机安装应用的包名:adb shell pm list packages -f
2:查看系统盘符:adb shell df
3:查看Log 1:adb shell 2: logcat | grep "abc"
4:删除应用:1:adbremount 2:adb shell 3:cdsystem/app 4:rm apk
5:安装APK: adbinstall -r apk 或者 adb pushapk /system/app
6:查看APP启动的时间指令
adb shell am start -W -ncomandroiddialer/DialtactsActivity (W是大写)执行命令后APP会自 动启动,其中ThisTime即是本次 App启动所花费的时间。
7:查看包名中当前所在进程信息:adb shell ps | grep +包名
8:查看Activity运行的任务栈:adb shell dumpsys activity
9:查看键值:adb logcat | grep intercep -i
10:查看模块所占有的CPU资源:adb shell top -d 2 -m 10
11:查看可用系统的权
$ adb shell
# pm list permissions
12:模拟按键的输入:adb shell input keyevent + 键值
eg: adb shell input keyevent 82 表示menu
adb shell input keyevent 3 表示home
adb shell input keyevent 19 表示up
adb shell input keyevent 20 表示down
adb shell input keyevent 21 表示left
adb shell input keyevent 22 表示right
adb shell input keyevent 66 表示enter
adb shell input keyevent 4 表示back
13:模拟滑动输入:adb shell input touchscreen <x1> <y1> <x2> <y2>
eg: adb shell input touchscreen swipe 18 665 18 350
14:启动一个Activity : adb shell am start -n 包名+类名
15:录制屏幕:adb shell screenrecord /sdcard/demomp4
16:重新启动:adb reboot
17:Monkey的基本用法下面是一个更为典型的命令行示例,它启动指定的应用程序,并向其发送500个伪随机事件:
$ adb shell monkey -p yourpackagename -v 500
如果跑桌面或者systemUi的monkey的话:
adb shell monkey -v -v -p 桌面包名 --pct-touch 50 --pct-motion 30 --pct-syskeys 20 --throttle 300 -s 200 200000
18:查找第三方应用的详细信息:
adb shell dumpsys package +第三方包名(comtxznetwebchat)
adb reboot edl 开机状态下,使用这个命令,可以重启电脑,进入edl模式,然后进行刷机
windows + r 打开 dos 窗口
输入 d : 进入 d 盘
输入 cd D: \ file\file 进入指定的文件路径 (这个路径是 adb shell-ok的文件路径)
adb devices 可以看到连接的设备。
adb logcat -v time打开日志
ctrl +c 暂停日志输出
adb logcat -c 清除日志
adb logcat -v time -b all |findstr fangfang findstr 前边是一根竖线, fangfang 是logd 的Tag 标签。 本条命令是查询日志
adb logcat -v time -b all >testtxt 将日志打印到 texttxt文件夹
adb shell am start -n comlenovocsdkcustom/MainActivity 启动某个应用的activity
adb install -r app-debugapk 安装APP到连接的设备
rm 文件 删除一个文件
双击一个文件,选中,按滑轮键,可以把相关文件加到输入那个地方。
ctrl +c 暂停日志输出
打开需要调试的应用 ,重现 crash
在adb 工具里边找到 texttxt 文件 打开 texttxt 文件 查找 调试应用的关键字 ,找到异常的日志,然后进行修改。
工作站里边命令使用
pwd
cd
ls
adb root
cd + 文件路径
adb logcat-c 清除日志
adb + shell 进入Linux命令
然后进入Linux之后 ,可以在dos下进行一些Linux 的一些命令的 *** 作,例如 cd sdcard 进入 sdcard , ls 查看当前目录下的文件 。 adb push U-NEXTapk /sdcard/ 将U-NEXT安装到sdcard中。
exit 从Linux 中退出到Dos
1,打开android studio 找到Terminal 并打开
2,输入命令C 进入c 盘;
3,输入命令 cd Users\Administrator 其中Administrator 文件下有个android 文件,输入命令 cd android ,然后就找到了 android
4,输入命令keytool -list -v -keystore 文件目录\自己的签名文件 比如我的:keytool -list -v -kyestore E:\签名文件\androidkeystore,接着按回车,然后输入秘钥: 回车 (秘钥库口令是看不到的)
adb shell pm list packages 查看所有包名
adb shell pm path packages 查看包名所属的apk
-----------------------
获取设备和软件版本信息
adb shell getprop
MAC地址 adb shell cat /sys/class/net/wlan0/address
adb shell:
获取ota信息
getprop |grep ota
获取 [robuildversionincremental]
getprop |grep inc
-----------------------
查看apk包名 aapt dump badging APK文件
查看包名信息: adb shell dumpsys package “comxxxxxx”
push 新的jar包
adb push frameworkjar /system/framework/
adb pull /system/priv-app/LenovoOTA/LenovoOTAapk C:\Users\admin\Desktop
失败提升需要root
adb root
adb remount
再次执行push -> adb push frameworkjar /system/framework/
然后 adb reboot
找到某个apk在系统的哪个路径下(comlenovocsdkplatform 为apk包名)
adb shell pm path comlenovocsdkplatform
启动某个应用的activity:adb shell am start -n comlenovocsdkcustom/MainActivity
恢复出厂设置 adb reboot recovery
adb logcat -s XXX logcat筛选
当前activity名(全路径) adb shell dumpsys window | findstr mCurrentFocus
adb reboot edl 输入进入线刷模式
fastboot 常用命令
1、adb reboot bootloader 进入fastboot 模式
2、fastboot flashing unlock 解锁unlock状态
3、fastboot flashing lock 锁定状态
4、fastboot erase data 清空data数据
5、fastboot format data 格式化data分区数据
6、fastboot getvar devices-state 得到锁的状态
7、fastboot erase boot 擦除boot分区
8、fastboot flash boot img 烧些img
9、fastboot reboot 重启
-------------------------
adb shell ps 查看自启信息
robuildversionincremental 固件信息名称
----------------------------
adb 启动界面
apps界面:adb shell am start -a androidsettingsAPPLICATION_SETTINGS
位置界面:adb shell am start -a androidsettingsLOCATION_SOURCE_SETTINGS
安全界面:adb shell am start -a androidsettingsSECURITY_SETTINGS
存储界面:adb shell am start -a androidsettingsINTERNAL_STORAGE_SETTINGS
电池界面:adb shell am start -a androidintentactionPOWER_USAGE_SUMMARY
账户界面:adb shell am start -a androidsettingsSYNC_SETTINGS
重置界面:adb shell am start -a androidsettingsBACKUP_AND_RESET_SETTINGS
蓝牙界面:adb shell am start -a androidsettingsBLUETOOTH_SETTINGS
开发者选项界面:adb shell am start -a androidsettingsAPPLICATION_DEVELOPMENT_SETTINGS
语言等选择界面:adb shell am start -a androidintentactionMAIN -c androidintentcategoryVOICE_LAUNCH
联系人:adb shell am start -a comandroidcontactsactionLIST_DEFAULT
----------------------------------------------------
Android 调试桥 (adb) ,可与设备进行通信。adb 命令可用于执行各种设备 *** 作(例如安装和调试应用),并提供对 Unix shell(可用来在设备上运行各种命令)的访问权限。它是一种客户端-服务器程序,包括以下三个组件:
客户端: 用于发送命令。客户端在开发机器上运行。可以通过发出 adb 命令从命令行终端调用客户端。(可以通过它对Android应用进行安装、卸载、调试)
PC上的手机助手基本都是通过adb命令去完成的。有时候装了这类手机助手的话,它自带的adb程序可能会与Android SDK下的adb程序产生冲突,5037端口被占用,导致adb命令无法连接到设备。Windows下通过netstat -ano|findstr "5037"
守护程序 (adbd): 用于在设备上运行命令。守护程序在每个设备上作为后台进程运行
执行adb shell ps | grep adbd, 可以找到该后台进程,Windows使用findstr替代grep
adb nodaemon server
服务器(Service): 用于管理客户端与守护程序之间的通信。服务器在开发机器上作为后台进程运行
adb服务启动后,Windows可以在任务管理中找到adbexe; linux ps -ef | gref adb 可以查看service
一般都是通过这样子的格式 adb [-d|-e|-s <设备序列号>] <子命令>
通常只有一台设备就忽略 [-d|-e|-s ] 这一部分
这里介绍一些常用的命令:
获取设备列表及设备状态
获取设备的状态
注意:设备的状态有 3 钟,device , offline , unknown
device:设备正常连接
offline:连接出现异常,设备无响应
unknown:没有连接设备
结束 adb 服务
启动 adb 服务
注意:通常两个命令一起用,有时候我们开启server会失败,这是因为我们装了的手机助手,豌豆荚或者其他软件自带有自己的adb,导致端口冲突开启失败。一般在连接出现异常,使用 adb devices 未正常列出设备, 设备状态异常时使用 kill-server,然后运行 start-server 进行重启服务。
打印 Android 的系统日志
打印 dumpsys、dumpstate、logcat 的输出,也是用于分析错误输出比较多
打印日志后重定向到一个文件中
安装应用,覆盖安装是使用 -r 选项
注意:有些adb版本无法支持安装中文的apk
查看手机应用包名
查看应用对应的apk文件在手机上的安装位置则可以在上面的命令后加-f参数
卸载应用,后面跟的参数是应用的包名,请区别于 apk 文件名
'-k' means keep the data and cache directories , -k 选项,卸载时保存数据和缓存目录
将 Android 设备上的文件或者文件夹复制到本地
adb pull /sdcard/testtxt C:\Users\Administrator\Desktop\log
推送本地文件至 Android 设备
获取连接到的手机的序列号
获取设备的连接状态
等待设备连接成功
该命令将会阻塞一直到默认连接的那部机器状态变为device,也就是连接成功。
其实adb shell命令就是调用的是Android设备中的system/bin目录下的命令。
Android的内核本身就是Linux,所以Android本身也支持Linux命令,但是因为是手机系统,所以进行了一定的删减,部分命令不支持,而不支持的部分,我们可以通过安装busybox这个软件进行。
如何在手机中执行Shell命令?
每次都加上adb shell来进行命令的发送与执行
先通过adb shell进入手机Shell执行状态,然后直接输入Linux命令。
使一个apk处于禁用状态,相当于卸载了:
其中 PACKAGE_OR_COMPONENT的格式是 package/class, 如 comUCMobile/mainUCMobile
eg:adb shell su disable comUCMobile/mainUCMobile
同时我们在手机上发现,UC浏览器的图标不见了
让一个apk从禁用状态恢复过来
其中 PACKAGE_OR_COMPONENT的格式是 package/class, 如 comUCMobile/mainUCMobileeg:
adb shell su enable comUCMobile/mainUCMobile
同时我们从手机上发现,UC浏览器的图标又出现了。
查看一个apk所在的路径
adb shell pm path comUCMobile
查看手机中装的所有的包
屏幕开始录像并且储存到/sdcard中,同时名字为demomp4
录屏设置时长10s,命名为demomp4
注意:现在仅支持一部分手机录屏,不支持的手机会出现以下提示
解决方法:
安装了scrcpy之后,只需要输入如下命令,即可录取指定设备的屏幕
scrcpy -s device --render-expired-frames -Nr /demopm4
--render-expired-frames:尽可能最大帧率
-N:不在PC端展示
-r:录制mp4/mkv文件
关闭设备请求,开启设备
设备关机以及重启
pm(package manager)可以获取一些安装到Android设备上的app的信息
pm list packages 用法:list packages [ options] filter
获取所有的应用的包名
列出系统应用
列出第三方应用
查看它们的关联文件
adb shell pm list package -f
查看软件包的安装来源
pm dump 包名 很多dump信息
安装应用
apk如果在电脑用 adb install
如果在Android设备上用 adb shell pm install
卸载应用,同adb uninstall ,后跟包名
清除应用数据
am(activity manager,字面意思就跟activity有关,大家都知道Android的界面都是由一个个activity显示的)
启动一个Activity
获取到package和launch_activity
AndroidSDK中aapt工具,检索命令结果,可以获取到package和launch_activity
这里涉及到一个点,如何找到程序的入口,首先你要知道是哪个activity才能启动;
启动华为系统相机
打开音乐播放器
播放指定音乐:
先停止目标应用,再启动
等待应用完成启动
启动网页(androidintentactionVIEW具体参考Android官网)
结束应用
input
模拟输入,向获得焦点的EditText控件输入内容
返回主界面
发送一个点击 *** 作的指令,参数是<x> <y>坐标
从左往右滑动屏幕, /从 100 100 经历300毫秒滑动到 200 200
长按 *** 作,在 100 100 位置长按 1000毫秒
以上就是关于android如何通过adb命令获取手机的IMEI全部的内容,包括:android如何通过adb命令获取手机的IMEI、通过什么adb指令可以查看已安装程序列表、adb的使用以及常见问题等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)