在Java中,我正在动态创建一组文件,我想在linux / unix文件系统上更改这些文件的文件权限。我希望能够执行chmod
的Java等价物。这可能是Java 5吗?如果是这样,怎么样?
我知道在Java 6中File
对象有setReadable()
/ setWritable()
个方法。我也知道我可以打电话来做这件事,但如果可能的话,我想避免这样做。
答案 0 :(得分:98)
Java 7中提供了对文件属性的完全控制,作为“新”新IO工具(NIO.2)的一部分。例如,可以使用setPosixFilePermissions()
,在现有文件上设置POSIX权限,或者使用createFile()
或newByteChannel()
.等方法创建文件时自动设置POSIX权限
您可以使用EnumSet.of()
创建一组权限,但辅助方法PosixFilePermissions.fromString()
将使用一种对许多开发人员更具可读性的传统格式。对于接受FileAttribute
的API,您可以使用PosixFilePermissions.asFileAttribute()
.
Set<PosixFilePermission> ownerWritable = PosixFilePermissions.fromString("rw-r--r--");
FileAttribute<?> permissions = PosixFilePermissions.asFileAttribute(ownerWritable);
Files.createFile(path, permissions);
在Java的早期版本中,使用您自己的本机代码或exec
命令行实用程序是常用的方法。
答案 1 :(得分:42)
除了erickson的建议之外,还有jna,它允许您在不使用jni的情况下调用本机库。它使用起来非常简单,我已经在几个项目中使用它并取得了巨大的成功。
唯一需要注意的是它比jni慢,所以如果你对大量的文件这样做可能会对你造成问题。
(编辑添加示例)
这是一个完整的jna chmod示例:
import com.sun.jna.Library;
import com.sun.jna.Native;
public class Main {
private static CLibrary libc = (CLibrary) Native.loadLibrary("c", CLibrary.class);
public static void main(String[] args) {
libc.chmod("/path/to/file", 0755);
}
}
interface CLibrary extends Library {
public int chmod(String path, int mode);
}
答案 2 :(得分:24)
在Java 6之前,Java级别不支持文件权限更新。您必须实现自己的本机方法或调用Runtime.exec()
来执行操作系统级别命令,例如 chmod 。
从Java 6开始,您可以使用File.setReadable()/File.setWritable()/File.setExecutable()
来设置文件权限。但它不模拟允许为不同用户设置权限的POSIX文件系统。 File.setXXX()仅允许为所有者和其他所有人设置权限。
从Java 7开始,引入了POSIX文件权限。您可以设置文件权限,就像您在* nix系统上所做的那样。语法是:
File file = new File("file4.txt");
file.createNewFile();
Set<PosixFilePermission> perms = new HashSet<>();
perms.add(PosixFilePermission.OWNER_READ);
perms.add(PosixFilePermission.OWNER_WRITE);
Files.setPosixFilePermissions(file.toPath(), perms);
此方法只能在POSIX文件系统上使用,这意味着您无法在Windows系统上调用它。
有关文件权限管理的详细信息,建议您阅读this post。
答案 3 :(得分:17)
:
public static void main(String[] args) throws IOException
{
Path file = Paths.get("c:/touch.txt");
AclFileAttributeView aclAttr = Files.getFileAttributeView(file, AclFileAttributeView.class);
System.out.println(aclAttr.getOwner());
for(AclEntry aclEntry : aclAttr.getAcl()){
System.out.println(aclEntry);
}
System.out.println();
UserPrincipalLookupService upls = file.getFileSystem().getUserPrincipalLookupService();
UserPrincipal user = upls.lookupPrincipalByName(System.getProperty("user.name"));
AclEntry.Builder builder = AclEntry.newBuilder();
builder.setPermissions( EnumSet.of(AclEntryPermission.READ_DATA, AclEntryPermission.EXECUTE,
AclEntryPermission.READ_ACL, AclEntryPermission.READ_ATTRIBUTES, AclEntryPermission.READ_NAMED_ATTRS,
AclEntryPermission.WRITE_ACL, AclEntryPermission.DELETE
));
builder.setPrincipal(user);
builder.setType(AclEntryType.ALLOW);
aclAttr.setAcl(Collections.singletonList(builder.build()));
}
答案 4 :(得分:9)
如果要为创建的文件设置777权限,则可以使用以下方法:
public void setPermission(File file) throws IOException{
Set<PosixFilePermission> perms = new HashSet<>();
perms.add(PosixFilePermission.OWNER_READ);
perms.add(PosixFilePermission.OWNER_WRITE);
perms.add(PosixFilePermission.OWNER_EXECUTE);
perms.add(PosixFilePermission.OTHERS_READ);
perms.add(PosixFilePermission.OTHERS_WRITE);
perms.add(PosixFilePermission.OTHERS_EXECUTE);
perms.add(PosixFilePermission.GROUP_READ);
perms.add(PosixFilePermission.GROUP_WRITE);
perms.add(PosixFilePermission.GROUP_EXECUTE);
Files.setPosixFilePermissions(file.toPath(), perms);
}
答案 5 :(得分:4)
您可以使用File类的方法: http://docs.oracle.com/javase/7/docs/api/java/io/File.html
答案 6 :(得分:4)
for Oracle Java 6:
private static int chmod(String filename, int mode) {
try {
Class<?> fspClass = Class.forName("java.util.prefs.FileSystemPreferences");
Method chmodMethod = fspClass.getDeclaredMethod("chmod", String.class, Integer.TYPE);
chmodMethod.setAccessible(true);
return (Integer)chmodMethod.invoke(null, filename, mode);
} catch (Throwable ex) {
return -1;
}
}
在solaris / linux下运行。
答案 7 :(得分:3)
除了erickson的答案之外,还有一个有用的链接,其中包含使用PosixFilePermissions的工作代码示例:
答案 8 :(得分:2)
Apache ant chmod(不是很优雅,为了完整性添加它)与@msorsky共享的信用
Chmod chmod = new Chmod();
chmod.setProject(new Project());
FileSet mySet = new FileSet();
mySet.setDir(new File("/my/path"));
mySet.setIncludes("**");
chmod.addFileset(mySet);
chmod.setPerm("+w");
chmod.setType(new FileDirBoth());
chmod.execute();
答案 9 :(得分:2)
只需更新此答案,除非以后有人遇到,因为您可以使用JDK 6
File file = new File('/directory/to/file');
file.setWritable(boolean);
file.setReadable(boolean);
file.setExecutable(boolean);
您可以在Oracle File(Java Platform SE 7)上找到文档。请记住,这些命令仅在当前工作用户拥有该文件的所有权或写入权限时才起作用。我知道OP希望使用chmod类型访问以实现更复杂的用户配置。这些将为所有用户全面设置该选项。
答案 10 :(得分:1)
simple java code for change file permission in java
String path="D:\\file\\read.txt";
File file=new File(path);
if (file.exists()) {
System.out.println("read="+file.canRead());
System.out.println("write="+file.canWrite());
System.out.println("Execute="+file.canExecute());
file.setReadOnly();
}
答案 11 :(得分:1)
import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.attribute.FileAttribute;
import java.nio.file.attribute.PosixFileAttributes;
import java.nio.file.attribute.PosixFilePermission;
import java.nio.file.attribute.PosixFilePermissions;
import java.util.Set;
public class FileAndDirectory1 {
public static void main(String[] args) {
File file = new File("fileTest1.txt");
System.out.println(file.getAbsoluteFile());
try {
//file.createNewFile();
if(!file.exists())
{
//PosixFilePermission is an enum class, PosixFilePermissions is a final class
//create file permissions from string
Set<PosixFilePermission> filePermissions = PosixFilePermissions.fromString("---------"/* "rwxrwxrwx" */);
FileAttribute<?> permissions = PosixFilePermissions.asFileAttribute(filePermissions);
Files.createFile(file.toPath(), permissions);
// printing the permissions associated with the file
System.out.println("Executable: " + file.canExecute());
System.out.println("Readable: " + file.canRead());
System.out.println("Writable: "+ file.canWrite());
file.setExecutable(true);
file.setReadable(true);
file.setWritable(true);
}
else
{
//modify permissions
//get the permission using file attributes
Set<PosixFilePermission> perms = Files.readAttributes(file.toPath(), PosixFileAttributes.class).permissions();
perms.remove(PosixFilePermission.OWNER_WRITE);
perms.add(PosixFilePermission.OWNER_READ);
perms.add(PosixFilePermission.OWNER_EXECUTE);
perms.add(PosixFilePermission.GROUP_WRITE);
perms.add(PosixFilePermission.GROUP_READ);
perms.add(PosixFilePermission.GROUP_EXECUTE);
perms.add(PosixFilePermission.OTHERS_WRITE);
perms.add(PosixFilePermission.OTHERS_READ);
perms.add(PosixFilePermission.OTHERS_EXECUTE);
Files.setPosixFilePermissions(file.toPath(), perms);
System.out.println("Executable: " + file.canExecute());
System.out.println("Readable: " + file.canRead());
System.out.println("Writable: "+ file.canWrite());
file.delete();
}
} catch (IOException e) {
e.printStackTrace();
}
Path path = Paths.get(String.valueOf(file));
System.out.println(path);
}
}
答案 12 :(得分:0)
有一个example class on Oracle Docs与UNIX chmod非常相似。它适用于java se 7+。