无法通过Java代码更改文件夹的权限
问题描述:
我创建了一个临时文件夹,然后尝试在我的Windows 7计算机中更改其权限。我有管理员权限。无法通过Java代码更改文件夹的权限
public class FilePermissionExample
{
public static void main(String[] args)
{
try {
File file = File.createTempFile("temp", Long.toString(System.nanoTime()));
file.delete();
file.mkdir();
if(file.exists()){
System.out.println("Is Execute allow : " + file.canExecute());
System.out.println("Is Write allow : " + file.canWrite());
System.out.println("Is Read allow : " + file.canRead());
}
file.setExecutable(false);
file.setReadable(false);
file.setWritable(false);
System.out.println("Is Execute allow : " + file.canExecute());
System.out.println("Is Write allow : " + file.canWrite());
System.out.println("Is Read allow : " + file.canRead());
if (file.createNewFile()){
System.out.println("File is created!");
}else{
System.out.println("File already exists.");
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
输出:
是execute允许:真
是写允许:真
是读允许:真
是execute允许:真
被写允许:真
被读允许: true
文件已存在。
预计:
是执行允许:真
被写允许:真
是读允许:真
是execute允许:假
被写允许:假
是读允许:假
我在使用hiverunner在windows中编写配置单元测试时遇到类似的问题。任何人都可以提出建议
答
从API-文档java.io.File
:
“的文件系统可以实现实际的文件系统对象上的限制,某些操作,如读,写,和执行这些限制被统称为访问权限文件系统可以在一个对象上拥有多组访问权限,例如,一个组可能适用于对象的所有者,另一组可能适用于所有其他用户,对象的访问权限可能会导致一些方法这个班要失败了。“
所以你的操作系统不允许改变权限。
答
如果您想更改NTFS格式驱动器的权限,您需要通过AclFileAttributeView更改权限。
下面的详细代码片段显示了委托人删除给定文件上的authorized users
的write
权限。
假设用户jane
是文件fobar.bin
的所有者和用户john
具有作为authorized user
写权限了。运行代码片段john
后,无法再写入该文件。
static final String AUTHENTICATED_USERS = "NT AUTHORITY\\Authenticated Users";
...
Path file = Paths.get("foobar.bin");
AclFileAttributeView view = Files.getFileAttributeView(
file, AclFileAttributeView.class);
// show current permissions for authenticated users
for (AclEntry acl : view.getAcl()) {
if (acl.principal().getName().equals(AUTHENTICATED_USERS)) {
System.out.printf("current permissions: %s%n", acl.permissions());
}
}
// remove the WRITE_DATA permission for authenticated users
// get list of current ACLs
List<AclEntry> acls = view.getAcl();
for (int i = 0; i < acls.size(); i++) {
UserPrincipal principal = acls.get(i).principal();
String principalName = principal.getName();
if (principalName.equals(AUTHENTICATED_USERS)) {
// get the current permissions
Set<AclEntryPermission> permissions = acls.get(i).permissions();
// remove WRITE_DATA permission
permissions.remove(AclEntryPermission.WRITE_DATA);
// create a new ACL entry
AclEntry entry = AclEntry.newBuilder()
.setType(AclEntryType.ALLOW)
.setPrincipal(principal)
.setPermissions(permissions)
.build();
// replace the ACL entry for authenticated users
acls.set(i, entry);
}
}
// set the updated list of ACLs
view.setAcl(acls);
// show updated permissions for authenticated users
for (AclEntry acl : view.getAcl()) {
if (acl.principal().getName().equals(AUTHENTICATED_USERS)) {
System.out.printf("updated permissions: %s%n", acl.permissions());
}
}
示例输出(线长包裹)
current permissions: [READ_NAMED_ATTRS, DELETE, EXECUTE, WRITE_ACL, \
WRITE_ATTRIBUTES, DELETE_CHILD, WRITE_DATA, READ_ATTRIBUTES, \
SYNCHRONIZE, WRITE_OWNER, APPEND_DATA, WRITE_NAMED_ATTRS, READ_DATA, \
READ_ACL]
updated permissions: [READ_NAMED_ATTRS, DELETE, EXECUTE, WRITE_ACL, \
WRITE_ATTRIBUTES, DELETE_CHILD, READ_ATTRIBUTES, SYNCHRONIZE, \
WRITE_OWNER, APPEND_DATA, WRITE_NAMED_ATTRS, READ_DATA, READ_ACL]
许可WRITE_DATA
已被删除。
什么返回方法setExecutable,setReadable和setWritable?如果使用setExecutable移除字符串会发生什么? –
它们都返回布尔值。 '假'正在被所有制定者返回。 我不明白你的第二个问题。这些方法将布尔作为参数而不是字符串。我没有使用字符串 – user2150837
如果操作系统不支持操作,这些操作可能会失败。我不知道如果Windows支持的可执行文件,所以我认为不支持和setExecutable方法失败的所有三个操作。 –