谷动谷力

 找回密码
 立即注册
查看: 2752|回复: 1
打印 上一主题 下一主题
收起左侧

Android中常用shell命令详解

[复制链接]
跳转到指定楼层
楼主
发表于 2021-3-5 14:01:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
【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查看文件
  1. ls -l /system/app/Demo.apk
  2. 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目录挂载,设置为可以读写
实例:
  1. 127|shell@android:/mnt/sdcard $ mount -o remount,rw /system
  2. mount -o remount,rw /system
  3. mount: Operation not permitted
复制代码

如果出现mount: Operation not permitted说明没有root权限
su获取ROOT权限
前提是你的手机已经root了
su命令表示切换ROOT用户下运行(就是说你有了root权限啦)
下面先获取root,获取root成功的时候$变成了#
  1. 255|shell@android:/mnt/sdcard $ su
  2. su
  3. root@android:/storage/sdcard0 # mount -o remount,rw /system
  4. mount -o remount,rw /system
复制代码

此时在执行挂载就可以成功
注意:$表示普通权限用户;#表示ROOT权限用户。
cp复制文件
cp -f /sdcard/SDKLongRrs.apk /system/app/SDKLongRrs.apk##
如果 cp: not found,说明该手机中cp命令不存在,换cat复制试试
  1. 127|root@android:/storage/sdcard0 # cat /sdcard/SDKLongRrs.apk> /system/app/SDKLongRrs.apk
  2. rs.apk> /system/app/SDKLongRrs.apk <
复制代码

右箭头>指明拷贝的方向哈
获取md5值
md5 /system/app/SDKLongRrs.apk
获取一个目录下所有文件的md5
md5 /system/app/*
chmod修改文件权限
让apk变成可以安装的
  1. chmod 644 /system/app/SDKLongRrs.apk
复制代码

pm安装apk卸载应用
  1. pm install -r /system/app/SDKLongRrs.apk
  2. pm uninstall com.baidu.map.location
复制代码

cmd安装apk卸载应用
  1. adb install C:\Users\Administrator\Desktop\Root.apk
复制代码

这个将电脑桌面的Root.apk安装到手机上
有可能不成功,直接看信息,对照英文找原因,比如小米的需要点击允许安装,在比如空间不足,在比如应用已经存在手机上
  1. adb uninstall com.baidu.map.location(你需要知道应用的包名哈)
复制代码

启动应用
(1)启动Activity
am start -n com.googleplayapp.storerootsuaction/.MainActivity( 你得知道对应的界面的Activity路径以及包名哈)
  1. adb shell am start -n com.test.provider/.MainActivity
复制代码

2)启动service
  1. <service
  2. android:name=".MyService"
  3. android:description="@string/Desciption"
  4. android:enabled="true"
  5. android:exported="true">
  6. <intent-filter>
  7. <action android:name="com.nandhan.myservice" />
  8. </intent-filter>
  9. </service><span> </span>

  10. <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 清除应用数据
  1. pm clear com.googleplayapp.storerootsuaction
复制代码

cmd下直接使用adb shell命令
如果不进入shell的,如何执行以上命令
cmd下面直接使用adb shell 后面跟上对应的命令就好
比如清除应用数据
  1. adb shell pm clear com.googleplayapp.storerootsuaction
复制代码

电脑输入文字到手机
比如手机要上百度,手机打开浏览器,点击地址栏,输入法切换到英文,cmd命令
  1. 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程序员而言的哈)
复制手机文件到电脑
  1. adb pull /sdcard/packages.xml C:\Users\linux\Desktop\packages.xml
复制代码

快速获取文件路径
打开cmd,将文件拖进来,你就可以看到文件的路径哈
eclipse中File Explorer的使用
手机调试模式连接电脑,使用File Explorer可以查看手机文件;
root以后的手机可以查看data下面的文件
如果已经root,但是data打不开,使用以下命令
cmd下面
adb shell
  1. shell@android:/ $ su root
  2. chmod -R 755 /data
复制代码

(R必须大写,linux命令区分大小写的,cmd命令不区分大小写,shell命令是一种linux命令)
点击这里查看chmod 755的含义
rm 删除命令
rm -r /mnt/sdcard/AppFolder/a.mp3 移除a.mp3文件
删除文件夹的时候需要加上-r参数
  1. rm -r /mnt/sdcard/AppFolder
复制代码

关闭程序
  1. adb shell am force-stop 包名
复制代码


一次卸载多个应用
  1. adb uninstall com.android.a
  2. adb uninstall com.android.b
  3. adb uninstall com.android.c
  4. adb uninstall com.android.d
  5. adb uninstall com.android.e
复制代码


将这多条命令写成一个.bat文件,直接点击bat就可以卸载多个应用了。
reboot重启手机
  1. adb reboot 重启
  2. adb reboot recovery 重启进入recovery模式
复制代码

cat查看文件
cat error.txt 这个命令可以查看error.txt文件的内容
批量执行多条adb shell命令
adb命令带参数,cmd下面带上参数,先获取su,然后做其他事
演示在cmd下面可以直接使用su权限来删除/system/bin/testa文件和/system/xbin/testb
  1. adb shell “su -c ‘rm -r -f /system/bin/testa’”
  2. adb shell “su -c ‘rm -r -f /system/xbin/testb’”
复制代码

如果是直接一条条执行shell命令将是下面的4条命令
  1. adb shell
  2. su
  3. rm -r -f /system/bin/testa
  4. rm -r -f /system/xbin/testb
复制代码

+10

本帖被以下淘专辑推荐:

  • · Shell|主题: 28, 订阅: 0
回复

使用道具 举报

沙发
 楼主| 发表于 2021-3-5 14:06:56 | 只看该作者
如何批量执行多条命令呢
写一个.bat文件,文件内容如下
  1. adb shell “su -c ‘rm -r -f /system/bin/testa’”
  2. adb shell “su -c ‘rm -r -f /system/xbin/testb’”
  3. pause
复制代码

保存为bat文件,直接点击执行.(windows系统下)。
(pause表示不关闭cmd窗口,这样就可以看到执行的结果了)
查看进程加载的库
可以根据进程id,查看进程加载了哪些库,cat /proc/pid/maps
kill 干掉进程
  1. adb shell am force-stop
复制代码

作用:强制关闭一个应用程序
举例:adb shell am force-stop com.lt.test
adb shell am force-stop比使用 kill -9 要方便
参考http://blog.sina.com.cn/s/blog_6294abe70101275q.html
ps可以查看到进程的pid
kill -s 9 pid干掉指定pid的进程
批量干掉进程
busybox pkill -9 父进程
  1. ps
  2. USER PID PPID VSIZE RSS WCHAN PC NAME
  3. u0_a145 10608 134 292960 26816 ffffffff 4019ca70 S com.ex.thre
  4. 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来过滤你想要的信息
  1. adb shell ps|findstr baidu
复制代码

这个命令找出手机上正在运行并且这个名字包含baidu的进程
//下面的写法也对
  1. adb shell ps baidu
  2. adb shell ps|findstr -i baidu
复制代码




引用块内容
对应的android或者linux中的shell命令是grep
  1. ps|gerp baidu
复制代码

引用块内容
提示 :有的手机上没有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
  1. androidid藏在这里[net.hostname]: [android-b33f3ac550112627]
复制代码



命令:getprop net.hostname
adb获取serialno
命令:getprop ro.boot.serialno或者getprop ro.serialno
adb获取imei
  1. service call iphonesubinfo 1
复制代码


使用”读取proc的方式”获取正在运行的进程
// 1,遍历”/proc”文件夹下面的文件夹,其中有些”文件夹名称”就是进程id(PID)
ls /proc
// 2,cat命令获取对应进程的名字(cat /proc/PID/cmdline)
cat /proc/1/cmdline 得到结果/init
查看进程具体的信息
(实例:12073是要查看的进程的PID)
  1. cat /proc/12073/maps 查看进程的文件结构
  2. cat /proc/12073/status 查看进程的状态
复制代码


通过packages.xml文件查看app安装信息
/data/system/packages.xml文件中,找到你应用相关内容
我在小米上使用cat /data/system/packages.xml命令得到以下数据
  1. <package
  2. name="com.trafficctr.miui" codePath="/system/app/TrafficControl"
  3. nativeLibraryPath="/system/app/TrafficControl/lib" flags="540229"
  4. ft="152fdda2cc0" it="152fdda2cc0" ut="152fdda2cc0" version="29"
  5. userId="10069">
  6. .....
  7. </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的进程优先级
  1. adb shell(进入shell)
  2. 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的进程
  1. adb shell ps|findstr /i “com.linux.test”
复制代码

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


查看最上层成activity名字
  1. adb shell dumpsys activity | findstr "mFocusedActivity"
复制代码

查看最上层窗口信息
  1. adb shell dumpsys window windows | findstr mCurrent
复制代码

修改host翻墙
1,电脑下载一个android版本的hosts,地址http://laod.cn/hosts/2016-google-hosts.html
2,将hosts放入手机中
  1. adb push C:\Users\Administrator\Downloads\Android安卓跟Linux系列\hosts /data/local/tmp/
  2. 3138 KB/s (154351 bytes in 0.048s)
复制代码

3,修改hosts文件(需要root权限)
C:\Users\Administrator>adb shell
  1. shell@android:/ $ su
  2. su
  3. shell@android:/ # mount -o remount,rw /system
  4. mount -o remount,rw /system
  5. shell@android:/ # cat /data/local/tmp/hosts>/system/etc/hosts
  6. cat /data/local/tmp/hosts>/system/etc/hosts
  7. shell@android:/ # ls -l /system/etc/hosts
  8. ls -l /system/etc/hosts
  9. -rw-r--r-- root root 154351 2016-09-28 17:53 hosts
  10. shell@android:/ #
复制代码




修改完毕,手机随便连接一个wifi或者打开数据流量就可以上google和facebook等等网站了。
查看端口
显示已连接的端口:netstat -ntup
显示正监听的端口:netstat -ntupl
查询端口进程应关系cat /proc/net/tcp6

如果查询14752端口被那个进程占用?
(1)16进制39A0=10进制14752;
(2)39A0对应的进程ID(也叫uid)是10096
  1. sl local_address remote_address st tx_queue rx_queue tr tm->when retrnsmt uid timeout inode
  2. 0:
  3. 00000000000000000000000000000000:39A0
  4. 00000000000000000000000000000000:0000 0A 00000000:00000000 00:00000000
  5. 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发送广播
  1. adb shell am broadcast -n com.lt.test/.MyBroadcast
  2. adb shell am broadcast -a “MyBroadcastAction”
复制代码

+10
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|深圳市光明谷科技有限公司|光明谷商城|Sunshine Silicon Corpporation ( 粤ICP备14060730号|Sitemap

GMT+8, 2024-12-27 08:59 , Processed in 0.079771 second(s), 38 queries .

Powered by Discuz! X3.2 Licensed

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表