谷动谷力
标题: Android中常用shell命令详解 [打印本页]
作者: 鸣涧_GC96O 时间: 2021-3-5 14:01
标题: Android中常用shell命令详解
【Shell】Android中常用shell命令详解
设置adb环境变量
其实就是将adb.exe的路径放到Path中,目的是cmd直接可以使用adb命令
比如我的adb.exe路径G:\tools\adt-bundle\sdk\platform-tools\adb.exe
我的电脑》高级》设置》环境变量》Path》增加G:\tools\adt-bundle\sdk\platform-tools
(注意不要adb.exe)
检测环境变量
打开cmd窗口,输入adb看效果
如果出现一堆adb信息说明配置成功
如果出现’adb’ is not recognized as an internal or external command
进入shell
adb shell
如果有多个设备怎么办?
adb devices查看你的设备;
adb -s xiaomi shell:-s命令表示选择设备,这里是选择xiaomi设备进shell
ls查看文件
- ls -l /system/app/Demo.apk
- rwxr-xr-x root root 48550 2016-02-22 21:55 CertificateInstallerProviders.apk
复制代码
Linux的文件基本上分为三个属性:可读(r),可写(w),可执行(x)。
对rwxr-xr-x 的解读:
rwx(Owner)r-x(Group)r-x(Other)
这个例子表示的权限是:使用者自己可读,可写,可执行;同一组的用户可读,不可写,可执行;其它用户可读,不可写,可执行。
命令中r=4,w=2,x=1,比如
chmod 644 system/app/Demo.apk命令执行以后,查看这个文件发现权限被修改了
ls -l /system/app/Demo.apk
-rw-r–r– root root 48550 2016-02-22 21:55 Demo.apk(将这个apk放在了system下面,而且还让它具有root权限了)
ls -a 列出当前目录下的所有文件
cd切换路径
cd /mnt/sdcard 切换到内存卡
mount挂载
mount -o remount,rw /system 将/system目录挂载,设置为可以读写
实例:
- 127|shell@android:/mnt/sdcard $ mount -o remount,rw /system
- mount -o remount,rw /system
- mount: Operation not permitted
复制代码
如果出现mount: Operation not permitted说明没有root权限
su获取ROOT权限
前提是你的手机已经root了
su命令表示切换ROOT用户下运行(就是说你有了root权限啦)
下面先获取root,获取root成功的时候$变成了#
- 255|shell@android:/mnt/sdcard $ su
- su
- root@android:/storage/sdcard0 # mount -o remount,rw /system
- mount -o remount,rw /system
复制代码
此时在执行挂载就可以成功
注意:$表示普通权限用户;#表示ROOT权限用户。
cp复制文件
cp -f /sdcard/SDKLongRrs.apk /system/app/SDKLongRrs.apk##
如果 cp: not found,说明该手机中cp命令不存在,换cat复制试试
- 127|root@android:/storage/sdcard0 # cat /sdcard/SDKLongRrs.apk> /system/app/SDKLongRrs.apk
- rs.apk> /system/app/SDKLongRrs.apk <
复制代码
右箭头>指明拷贝的方向哈
获取md5值
md5 /system/app/SDKLongRrs.apk
获取一个目录下所有文件的md5
md5 /system/app/*
chmod修改文件权限
让apk变成可以安装的
- chmod 644 /system/app/SDKLongRrs.apk
复制代码
pm安装apk卸载应用
- pm install -r /system/app/SDKLongRrs.apk
- pm uninstall com.baidu.map.location
复制代码
cmd安装apk卸载应用
- adb install C:\Users\Administrator\Desktop\Root.apk
复制代码
这个将电脑桌面的Root.apk安装到手机上
有可能不成功,直接看信息,对照英文找原因,比如小米的需要点击允许安装,在比如空间不足,在比如应用已经存在手机上
- adb uninstall com.baidu.map.location(你需要知道应用的包名哈)
复制代码
启动应用
(1)启动Activity
am start -n com.googleplayapp.storerootsuaction/.MainActivity( 你得知道对应的界面的Activity路径以及包名哈)
- adb shell am start -n com.test.provider/.MainActivity
复制代码
(2)启动service
- <service
- android:name=".MyService"
- android:description="@string/Desciption"
- android:enabled="true"
- android:exported="true">
- <intent-filter>
- <action android:name="com.nandhan.myservice" />
- </intent-filter>
- </service><span> </span>
- <strong style="margin: 0px; padding: 0px;">adb shell am startservice com.nandhan.myservice/.MyService</strong>
复制代码
查看正在运行的 Services
adb shell dumpsys activity services [<packagename>]
包名是必须的、不需要写完整的包名、支持模糊匹配
例如adb shell dumpsys activity services com.linux.example
查看正在运行的 activity
adb shell dumpsys activity [<packagename>]
包名是必须的、不需要写完整的包名、支持模糊匹配
例如adb shell dumpsys activity com.linux.example
clear 清除应用数据
- pm clear com.googleplayapp.storerootsuaction
复制代码
cmd下直接使用adb shell命令
如果不进入shell的,如何执行以上命令
cmd下面直接使用adb shell 后面跟上对应的命令就好
比如清除应用数据
- adb shell pm clear com.googleplayapp.storerootsuaction
复制代码
电脑输入文字到手机
比如手机要上百度,手机打开浏览器,点击地址栏,输入法切换到英文,cmd命令
- adb shell input text "www.baidu.com"
复制代码
你会看到手机浏览器的网址变成百度了
文件传输
电脑复制文件到手机
方法1:cmd下面使用push命令
adb push “C:\Users\Administrator\Downloads\Root.apk” /mnt/sdcard/goodRoot/
将电脑下载里面的Root.apk复制到手机sdcard的goodRoot文件夹下面
方法2:直接使用eclipse里面的File Explorer(对android程序员而言的哈)
复制手机文件到电脑
- adb pull /sdcard/packages.xml C:\Users\linux\Desktop\packages.xml
复制代码
快速获取文件路径
打开cmd,将文件拖进来,你就可以看到文件的路径哈
eclipse中File Explorer的使用
手机调试模式连接电脑,使用File Explorer可以查看手机文件;
root以后的手机可以查看data下面的文件
如果已经root,但是data打不开,使用以下命令
cmd下面
adb shell
- shell@android:/ $ su root
- chmod -R 755 /data
复制代码
(R必须大写,linux命令区分大小写的,cmd命令不区分大小写,shell命令是一种linux命令)
点击这里查看chmod 755的含义
rm 删除命令
rm -r /mnt/sdcard/AppFolder/a.mp3 移除a.mp3文件
删除文件夹的时候需要加上-r参数
- rm -r /mnt/sdcard/AppFolder
复制代码
关闭程序
- adb shell am force-stop 包名
复制代码
一次卸载多个应用
- adb uninstall com.android.a
- adb uninstall com.android.b
- adb uninstall com.android.c
- adb uninstall com.android.d
- adb uninstall com.android.e
复制代码
将这多条命令写成一个.bat文件,直接点击bat就可以卸载多个应用了。
reboot重启手机
- adb reboot 重启
- adb reboot recovery 重启进入recovery模式
复制代码
cat查看文件
cat error.txt 这个命令可以查看error.txt文件的内容
批量执行多条adb shell命令
adb命令带参数,cmd下面带上参数,先获取su,然后做其他事
演示在cmd下面可以直接使用su权限来删除/system/bin/testa文件和/system/xbin/testb
- adb shell “su -c ‘rm -r -f /system/bin/testa’”
- adb shell “su -c ‘rm -r -f /system/xbin/testb’”
复制代码
如果是直接一条条执行shell命令将是下面的4条命令
- adb shell
- su
- rm -r -f /system/bin/testa
- rm -r -f /system/xbin/testb
复制代码
作者: 鸣涧_GC96O 时间: 2021-3-5 14:06
如何批量执行多条命令呢
写一个.bat文件,文件内容如下:
- adb shell “su -c ‘rm -r -f /system/bin/testa’”
- adb shell “su -c ‘rm -r -f /system/xbin/testb’”
- pause
复制代码
保存为bat文件,直接点击执行.(windows系统下)。
(pause表示不关闭cmd窗口,这样就可以看到执行的结果了)
查看进程加载的库
可以根据进程id,查看进程加载了哪些库,cat /proc/pid/maps
kill 干掉进程
- ps
- USER PID PPID VSIZE RSS WCHAN PC NAME
- u0_a145 10608 134 292960 26816 ffffffff 4019ca70 S com.ex.thre
- u0_a146 10755 134 302420 32152 ffffffff 4019ca70 S com.ex.two
复制代码
使用kill -s 9 134,就可以干掉 PID =134. PID =10608. PID =10755三个进程
查看内存信息
看手机内存信息cat /proc/meminfo
查看应用的内存信息 dumpsys meminfo 应用包名
查看应用是否安装
查看应用的安装路径 pm path 应用包名
获取手机上已经安装的所有的程序 pm list packages
过滤grep 和findstr
引用块内容
在windows上直接使用findstr来过滤你想要的信息
- adb shell ps|findstr baidu
复制代码
这个命令找出手机上正在运行并且这个名字包含baidu的进程
//下面的写法也对
- adb shell ps baidu
- adb shell ps|findstr -i baidu
复制代码
引用块内容
对应的android或者linux中的shell命令是grep
引用块内容
提示 :有的手机上没有grep命令,这时候可以采用findstr;或者往手机里放一个busybox文件,然后使用busybox grep命令,效果一样
查看运行的程序
查看手机正在运行的程序 ps
查看自己的程序是否在运行 ps | grep 应用包名
如果没有grep命令,可以放置一个busybox工具到手机
查看360对应的程序是否在运行 ps | busybox grep m.qihoo*
删除多个文件
cd dir
rm * 删除dir中所有文件
adb获取手机参数
adb获取手机所有参数参考这个
adb shell getprop
adb获取iccid
service call iphonesubinfo 4(需要权限android.permission.READ_PHONE_STATE)
adb获取imei
adb -d shell dumpsys iphonesubinfo
adb获取androidid
- androidid藏在这里[net.hostname]: [android-b33f3ac550112627]
复制代码
命令:getprop net.hostname
adb获取serialno
命令:getprop ro.boot.serialno或者getprop ro.serialno
adb获取imei
- service call iphonesubinfo 1
复制代码
使用”读取proc的方式”获取正在运行的进程
// 1,遍历”/proc”文件夹下面的文件夹,其中有些”文件夹名称”就是进程id(PID)
ls /proc
// 2,cat命令获取对应进程的名字(cat /proc/PID/cmdline)
cat /proc/1/cmdline 得到结果/init
查看进程具体的信息
(实例:12073是要查看的进程的PID)
- cat /proc/12073/maps 查看进程的文件结构
- cat /proc/12073/status 查看进程的状态
复制代码
通过packages.xml文件查看app安装信息
在/data/system/packages.xml文件中,找到你应用相关内容
我在小米上使用cat /data/system/packages.xml命令得到以下数据
- <package
- name="com.trafficctr.miui" codePath="/system/app/TrafficControl"
- nativeLibraryPath="/system/app/TrafficControl/lib" flags="540229"
- ft="152fdda2cc0" it="152fdda2cc0" ut="152fdda2cc0" version="29"
- userId="10069">
- .....
- </package>
复制代码
显然name就是包名,codePath就是安装的路径
使用shell启动和终止模拟器
adb shell stop//停止
adb shell start//启动
多设备选择
adb devices//显示处于调式模式的devices
adb -s emulator-5554 shell //表示选择5554模拟器的进入shell
42.busybox的安装
查看进程优先级
假设要查看程序com.test.app.a的进程优先级
- adb shell(进入shell)
- ps|grep com.test.app.a(列出这个进程)
复制代码
cat /proc/28155/oom_adj(获取这个进程的adj值)
adj值则在ProcessList中定义,adj的取值范围[-17,16],取值越大说明优先级越低。adj取值说明参考这里
dumpsys 查看内存,cpu,电量信息
1)查看所有内存信息
命令:dumpsys meminfo
2)查看某个包的内存信息
命令:dumpsys pkg_name
3)查看CPU信息
命令:adb shell dumpsys cpuinfo
4)查看电量信息
命令:dumpsys battery
参考这里:Android 通过adb shell命令查看内存,CPU,启动时间,电量等信息
findstr 和grep过滤搜索
1)cmd下搜索包名为com.linux.test的进程
- adb shell ps|findstr /i “com.linux.test”
复制代码
2)shell下面搜索
先使用adb shell进去,然后使用grep命令过滤
查看最上层成activity名字
- adb shell dumpsys activity | findstr "mFocusedActivity"
复制代码
查看最上层窗口信息
- adb shell dumpsys window windows | findstr mCurrent
复制代码
- adb push C:\Users\Administrator\Downloads\Android安卓跟Linux系列\hosts /data/local/tmp/
- 3138 KB/s (154351 bytes in 0.048s)
复制代码
3,修改hosts文件(需要root权限)
C:\Users\Administrator>adb shell
- shell@android:/ $ su
- su
- shell@android:/ # mount -o remount,rw /system
- mount -o remount,rw /system
- shell@android:/ # cat /data/local/tmp/hosts>/system/etc/hosts
- cat /data/local/tmp/hosts>/system/etc/hosts
- shell@android:/ # ls -l /system/etc/hosts
- ls -l /system/etc/hosts
- -rw-r--r-- root root 154351 2016-09-28 17:53 hosts
- shell@android:/ #
复制代码
修改完毕,手机随便连接一个wifi或者打开数据流量就可以上google和facebook等等网站了。
查看端口
显示已连接的端口:netstat -ntup
显示正监听的端口:netstat -ntupl
查询端口进程应关系cat /proc/net/tcp6
如果查询14752端口被那个进程占用?
(1)16进制39A0=10进制14752;
(2)39A0对应的进程ID(也叫uid)是10096
- sl local_address remote_address st tx_queue rx_queue tr tm->when retrnsmt uid timeout inode
- 0:
- 00000000000000000000000000000000:39A0
- 00000000000000000000000000000000:0000 0A 00000000:00000000 00:00000000
- 00000000 10096 0 8887 1 00000000 100 0 0 2 -1
复制代码
(3)使用ps命令
在android中,uid大于10000的是应用程序创建的用户。
ps的第一列是uid,大于10000的uid会以u0_a开头,10096 显示为u0_a96,最后一列就是进程名。
adb发送广播
- adb shell am broadcast -n com.lt.test/.MyBroadcast
- adb shell am broadcast -a “MyBroadcastAction”
复制代码
欢迎光临 谷动谷力 (http://bbs.sunsili.com/) |
Powered by Discuz! X3.2 |