Android中常用shell命令

来源:互联网 发布:制作动画的软件免费 编辑:程序博客网 时间:2024/05/16 00:56

注意事项:这里写的命令,网页会重新编辑格式,比如我写了两个减号,发布后变成了一个减号;如果我>说的命令不能正确执行,请手动输入命令,切记切换英文状态。
android 常用shell命令记录下来备忘
\n在shell命令中的作用是换行(而\r\n会将一个二进制文件格式从unicode变为混合格式)
&可以用来连接多个命令

设置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路径以及包名哈)
(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>     

adb shell am startservice com.nandhan.myservice/.MyService

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.aadb uninstall com.android.badb uninstall com.android.cadb uninstall com.android.dadb 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
如何批量执行多条命令呢
写一个.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 干掉进程

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 父进程
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的进程

引用块内容

对应的android或者linux中的shell命令是grep
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
androidid藏在这里[net.hostname]: [android-b33f3ac550112627]
命令:getprop net.hostname
adb获取serialno
命令:getprop ro.boot.serialno或者getprop ro.serialno
adb获取imei
service call iphonesubinfo 1
更多信息参考这个
http://stackoverflow.com/questions/27002663/adb-shell-dumpsys-iphonesubinfo-not-working-since-android-5-0-lollipop

使用”读取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的安装
buxybox

查看进程优先级

假设要查看程序com.test.app.a的进程优先级
adb shell(进入shell)
ps|grep com.test.app.a(列出这个进程)

u0_a37    28155 164   909516 36900 ffffffff b75baa27 S 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命令过滤
ps|grep “com.linux.test”

adb 查看最上层成activity名字

adb shell dumpsys activity | findstr "mFocusedActivity"

修改host翻墙

1,电脑下载一个android版本的hosts,地址http://laod.cn/hosts/2016-google-hosts.html
2,将hosts放入手机中

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 shellshell@android:/ $ susushell@android:/ # mount -o remount,rw /systemmount -o remount,rw /systemshell@android:/ # cat  /data/local/tmp/hosts>/system/etc/hostscat  /data/local/tmp/hosts>/system/etc/hostsshell@android:/ # ls -l /system/etc/hostsls -l /system/etc/hosts-rw-r--r-- root     root       154351 2016-09-28 17:53 hostsshell@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,最后一列就是进程名。

1 0
原创粉丝点击