其实就是将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
adb shell
如果有多个设备怎么办?
adb devices查看你的设备;
adb -s xiaomi shell:-s命令表示选择设备,这里是选择xiaomi设备进shell
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 /mnt/sdcard 切换到内存卡
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权限
前提是你的手机已经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 -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 /system/app/SDKLongRrs.apk
获取一个目录下所有文件的md5
md5 /system/app/*
让apk变成可以安装的
chmod 644 /system/app/SDKLongRrs.apk
pm install -r /system/app/SDKLongRrs.apk
pm uninstall com.baidu.map.location
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>
adb shell am startservice com.nandhan.myservice/.MyService
adb shell dumpsys activity services []
包名是必须的、不需要写完整的包名、支持模糊匹配
例如adb shell dumpsys activity services com.linux.example
adb shell dumpsys activity []
包名是必须的、不需要写完整的包名、支持模糊匹配
例如adb shell dumpsys activity com.linux.example
pm clear com.googleplayapp.storerootsuaction
如果不进入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,将文件拖进来,你就可以看到文件的路径哈
手机调试模式连接电脑,使用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 -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就可以卸载多个应用了。
adb reboot 重启
adb reboot recovery 重启进入recovery模式
cat error.txt 这个命令可以查看error.txt文件的内容
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
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
引用块内容
在windows上直接使用findstr来过滤你想要的信息
adb shell ps|findstr baidu
这个命令找出手机上正在运行并且这个名字包含baidu的进程
//下面的写法也对
adb shell ps baidu
adb shell ps|findstr -i 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 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
// 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 查看进程的状态
在/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就是安装的路径
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(列出这个进程)
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取值说明参考这里
1)查看所有内存信息
命令:dumpsys meminfo
2)查看某个包的内存信息
命令:dumpsys pkg_name
3)查看CPU信息
命令:adb shell dumpsys cpuinfo
4)查看电量信息
命令:dumpsys battery
参考这里:Android 通过adb shell命令查看内存,CPU,启动时间,电量等信息
1)cmd下搜索包名为com.linux.test的进程
adb shell ps|findstr /i “com.linux.test”
2)shell下面搜索
先使用adb shell进去,然后使用grep命令过滤
ps|grep “com.linux.test”
adb shell dumpsys activity | findstr "mFocusedActivity"
adb shell dumpsys window windows | findstr mCurrent
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 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 shell am broadcast -n com.lt.test/.MyBroadcast
adb shell am broadcast -a “MyBroadcastAction”