Android 设备调试有两种连线方式:有线和无线;
有线是通过USB导线连接android设备和电脑端,无线方式是通过连接WIFI,通过TCP的方式,连接设备和电脑端,一般用 5555端口;
有线的调节,只需要打开调试模式基本就可以了,无线连接方式比有线多一步操作,就是需要先通过usb导线连接后,adb 命令行:adb tcpip 5555 开启tcp 连接5555端口;
正常过程是这样的,但是日常开发的时候经常遇到,没有带线,没有笔记本备用,设备不在身边(在隔壁)的情况,设备每次重启都会关闭tcp 555端口,不可能每次都需要拿着电脑/导线去设备前调试,而且,公司没有给我配置笔记本```
这个情况下,就需要设置adb 自动监听5555端口,而且需要重启有效,
说明 : 该情况适用于 root 的设备;
1.adb 查看root权限
我们先通过导线连接设备,通过adb 命令判断,命令行输入 adb shell,#代表已经root过,$代表没有root权限;
(还好还好,我们的屏/设备 属于root过的设备,具有root权限)
2.修改文件
修改/default.prop或者/system/build.prop文件
//添加这一行
service.adb.tcp.port=5555
文件后可以添加这一行
但是你会发现/system 文件夹是只读权限的.
你可以通过如下的命令查看该文件权限;
adb shell ls -l /system
这个是我修改后的,你可以看看你的;
要修改build.prop文件,是修改不了的,所以需要解决的是如何修改;
3.Android9.0挂载system文件夹读写
我们知道在Android系统中,system文件夹一般都是只读属性,不管你是root用户还是普通权限用户,所以在开发中,如果我们想要访问和修改system文件夹下的内容的话就需要获取system文件夹的写属性,而因为Android版本的变化,在不同版本下system文件夹修改读写属性的方式也有较大的区别。
Android 8.0以下版本
第一步:要得到system分区的全名
adb shell
mount
rootfs / rootfs ro 0 0
tmpfs /dev tmpfs rw,mode=755 0 0
devpts /dev/pts devpts rw,mode=600 0 0
proc /proc proc rw 0 0
sysfs /sys sysfs rw 0 0
tmpfs /sqlite_stmt_journals tmpfs rw,size=4096k 0 0
none /dev/cpuctl cgroup rw,cpu 0 0
/dev/block/mtdblock0 /system yaffs2 ro 0 0
/dev/block/mtdblock1 /data yaffs2 rw,nosuid,nodev 0 0
/dev/block/mtdblock2 /cache yaffs2 rw,nosuid,nodev 0 0
/dev/block//vold/179:0 /sdcard vfat rw,dirsync,nosuid,nodev,noexec,uid=1000,gid=1015,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=iso8859-1,shortname=mixed,utf8,errors=remount-ro 0 0
从/dev/block/mtdblock0 /system yaffs2 ro 0 0 部分可以看得出/system的权限是ro即是read only。
第二步:根据名称重新挂载
mount -o remount /dev/block/mtdblock0 /system
mount
rootfs / rootfs ro 0 0
tmpfs /dev tmpfs rw,mode=755 0 0
devpts /dev/pts devpts rw,mode=600 0 0
proc /proc proc rw 0 0
sysfs /sys sysfs rw 0 0
tmpfs /sqlite_stmt_journals tmpfs rw,size=4096k 0 0
none /dev/cpuctl cgroup rw,cpu 0 0
/dev/block/mtdblock0 /system yaffs2 rw 0 0
/dev/block/mtdblock1 /data yaffs2 rw,nosuid,nodev 0 0
/dev/block/mtdblock2 /cache yaffs2 rw,nosuid,nodev 0 0
/dev/block//vold/179:0 /sdcard vfat rw,dirsync,nosuid,nodev,noexec,uid=1000,gid=1015,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=iso8859-1,shortname=mixed,utf8,errors=remount-ro 0 0
可以看到/dev/block/mtdblock0 /system yaffs2 rw 0 0,/system拥有rw的权限。
如果要改回去ro权限的话,执行:
mount -o remount,ro /dev/block/mtdblock0 /system
当/system 目录为读写权限后,就可以随意删除或者替换系统应用了。
Android 8.0以上版本
在Android8.0以上通过以上mount命令,你会发现找不到/system代表的节点和拥有的权限信息,这是因为Android8.0之后谷歌加入了A/B system的特性,system分区跟ramdisk分区打包在一起,因此系统起来之后也就不存在system分区了,而是直接把system镜像挂载到/根目录上。所以/proc/mounts文件中没有包含/system的权限信息,此时如果使用上面的命令:
mount -o remount,rw /system
重新挂载/system分区会报错:
mount: '/system' not in /proc/mounts
因此使用这条命令是不可行的,需要使用下述的命令:
mount -o remount -o rw /
使用这条命令可以临时挂载上/system文件夹,直到下一次重启。
其实为什么root用户会出现/system文件夹无权限写的情况的话,主要原因是/system所属的用户组不是root,而是system用户组,所以需要重新挂载。
当然上面方法不能挂载/system目录的话而且提示“’/dev/root’ is read-only”的话,那么是因为你的设备开启了avb,此时就只能通过下面的方式完全重新挂载整个系统(当然,我暂时没遇到这个情况,大家可以留意一下):
adb root
adb disable-verity
adb remount
如果adb disable-verity提示需要解锁OEM的话,那么还需要先解锁OEM:
adb reboot fastboot
fastboot oem unlock
fastboot reboot
提示解锁成功的话,重新执行命令就不会报错了。
4.再修改/system/build.prop
这个时候你就只可以直接操作/system文件夹下的文件了, adb pull,adb push 都可以用了,不过有没有办法可以在android shell中编辑这些文件(比如Linux shell中的vim编辑器)呢,
我看到有个文件说你可以用cat命令,好吧
您可以使用以下方法创建文本
$ cat > filename.txt
您可以使用以下方法向文本文件添加行:
$ cat >> filename.txt
两个命令都可以使用终止ctrl-D
.
大家也可以试一下,这个也行,cat file文件还可以查看内容~~~
当然,我最后用的还是adb pull到本地,修改后直接adb push~
5.测试一下
这个时候直接新开一个命令窗口,直接adb connect IP:5555,好吧,我尝试的第一次没反应,然后我直接adb reboot,重启之后重新adb connect IP:5555,竟然真的成功了!然后我重新关机重启,还是可以的,
6.收尾操作
为了设备安全,我们功能完成之后别忘了恢复只读权限
//设置可读写权限
# mount -o rw,remount /system
//恢复只可读
# mount -o ro,remount /system
至此,就算结束了,重启手机还是会生效的
7.代码实现(还未实现)
下面是我打算用代码/程序实现该功能的草稿,下面的函数方法去实现(主要方法)
public void openPort5555()
{
try
{
String cmds[] = {
"setprop service.adb.tcp.port 5555",
"stop adbd",
"start adbd"
};
for (int i = 0; i < cmds.length; i++)
{
java.lang.Process process = Runtime.getRuntime().exec(cmds[i]);
int exitCode = process.waitFor();
if (exitCode != 0)
{
throw new java.io.IOException("Command exited with " + exitCode);
}
}
Toast.makeText(this, "Listening on port 55555...", Toast.LENGTH_LONG).show();
}
catch (Exception ex)
{
ex.printStackTrace();
Toast.makeText(this, "An error has occurred: " + ex, Toast.LENGTH_LONG).show();
}
}
大家可以尝试一下;
8.drwxrwxrwx
前面的 d 表示这是一个文件夹,后面的 rwxrwxrwx 则表示文件夹的权限:
第 1 个字符表示文件类型(d 表示目录,- 表示普通文件)
第 2~4 个字符表示文件所有者的权限(rwx 表示可读、可写、可执行)
第 5~7 个字符表示文件所在组的权限(rwx 表示可读、可写、可执行)
第 8~10 个字符表示其他用户的权限(rwx 表示可读、可写、可执行)
在这个例子中,文件夹 /sdcard/myfolder 的权限为可读、可写、可执行,无论是文件所有者、文件所在组还是其他用户。在 Linux 系统中,文件和目录都有属主(owner)和属组(group)。
文件所有者(owner)指的是文件或目录的拥有者,拥有者有最高的权限,可以对文件或目录进行任何操作。
文件所在组(group)指的是文件或目录所属的组,该组中的用户具有一定的权限,能对文件或目录进行特定的操作。
其他用户指的是除了文件所有者和文件所在组的其他用户,这些用户通常拥有最低的权限,只能进行特定的操作。
Linux 系统中的文件和目录权限是以用户身份和用户组身份来区分的,每个文件或目录都有三组权限,分别是文件所有者的权限、文件所在组的权限和其他用户的权限。
第8项 属于水文字的,大家了解一下知识点就可以了,关于第7项,之后我会再继续尝试一下实现的;
参考资料:文章来源:https://uudwc.com/A/Nx562
https://blog.csdn.net/baidu_38661691/article/details/107481148
https://blog.csdn.net/u013168615/article/details/128560120文章来源地址https://uudwc.com/A/Nx562