如何使用NIO.2接口在Linux上动态调整PosixFilePermissions的文件权限?
- 内容介绍
- 文章标签
- 相关推荐
本文共计685个文字,预计阅读时间需要3分钟。
PosixFilePermissions 是 Java NIO.2 提供的用于生成符合 POSIX 标准的文件权限集的工具类。
理解 PosixFilePermissions 的作用边界
这个类不执行系统调用,也不解析或映射 Linux 的八进制权限码(如 755)。它只提供静态工厂方法,把字符串(如 "rwxr-xr--")或枚举值转为 Java 内部的权限集合。是否生效取决于:
- 运行环境必须是支持 POSIX 的文件系统(Linux、macOS 等),Windows 不支持该 API;
- 目标文件必须由当前 JVM 进程有权限修改(即进程用户是文件所有者,或为 root);
- 路径必须指向真实存在的文件或目录(对符号链接默认操作其目标)。
常用权限构造方式
两种主流写法,语义清晰且不易出错:
-
字符串方式:
PosixFilePermissions.fromString("rw-r--r--")→ 对应八进制 644; -
枚举组合方式:
EnumSet.of(OWNER_READ, OWNER_WRITE, GROUP_READ, OTHERS_READ)→ 同样是 644。
注意:字符串中顺序固定为 owner/group/others,每组三位,不可省略破折号(如 "rw-r--r--" 合法,"rw-r-r--" 非法)。
本文共计685个文字,预计阅读时间需要3分钟。
PosixFilePermissions 是 Java NIO.2 提供的用于生成符合 POSIX 标准的文件权限集的工具类。
理解 PosixFilePermissions 的作用边界
这个类不执行系统调用,也不解析或映射 Linux 的八进制权限码(如 755)。它只提供静态工厂方法,把字符串(如 "rwxr-xr--")或枚举值转为 Java 内部的权限集合。是否生效取决于:
- 运行环境必须是支持 POSIX 的文件系统(Linux、macOS 等),Windows 不支持该 API;
- 目标文件必须由当前 JVM 进程有权限修改(即进程用户是文件所有者,或为 root);
- 路径必须指向真实存在的文件或目录(对符号链接默认操作其目标)。
常用权限构造方式
两种主流写法,语义清晰且不易出错:
-
字符串方式:
PosixFilePermissions.fromString("rw-r--r--")→ 对应八进制 644; -
枚举组合方式:
EnumSet.of(OWNER_READ, OWNER_WRITE, GROUP_READ, OTHERS_READ)→ 同样是 644。
注意:字符串中顺序固定为 owner/group/others,每组三位,不可省略破折号(如 "rw-r--r--" 合法,"rw-r-r--" 非法)。

