以下是我的代码:
String DirectoryPath = "/Users/xxx/uploads/image";
Path newDirectoryPath = Paths.get(DirecotryPath);
if (!Files.exists(newDirectoryPath)) {
Set<PosixFilePermission> permissions = PosixFilePermissions.fromString("rwxrwxrwx");
FileAttribute<Set<PosixFilePermission>> fileAttributes = PosixFilePermissions.asFileAttribute(permissions);
Files.createDirectories(newDirectoryPath, fileAttributes);
}
创建目录后,目录的权限不是777。
答案 0 :(得分:3)
这是因为执行用户的实际umask设置。
在文件创建时设置访问权限时,权限的实际值可能与属性对象的值不同。其原因是具体实施。例如,在UNIX系统上,进程具有影响新创建文件的权限位的umask。如果实现支持访问权限的设置,并且底层文件系统支持访问权限,则需要实际访问权限的值等于或小于提供给createFile或createDirectory方法的属性的值。 换句话说,该文件可能比请求的更安全。
例如
<强> Posix.java 强>
// add the omitted import statements
public class Posix {
public static void main(String[] args) throws IOException {
Path newDirectoryPath = Paths.get("/tmp/image");
Files.deleteIfExists(newDirectoryPath);
Set<PosixFilePermission> permissions
= PosixFilePermissions.fromString("rwxrwxrwx");
FileAttribute<Set<PosixFilePermission>> fileAttributes
= PosixFilePermissions.asFileAttribute(permissions);
Files.createDirectories(newDirectoryPath, fileAttributes);
}
}
在shell中执行
$ cd /tmp
$ javac Posix.java
$ umask 001
$ java Posix
$ ls -ld image/
drwxrwxrw-. 2 suboptimal suboptimal 6 Jul 5 12:38 image/
$ umask 002
$ java Posix
$ ls -ld image/
drwxrwxr-x. 2 suboptimal suboptimal 6 Jul 5 12:38 image/
$ umask 004
$ java Posix
$ ls -ld image/
drwxrwx-wx. 2 suboptimal suboptimal 6 Jul 5 12:38 image/