您遇到了特定于 MacOS 的问题。在 MacOS 中检查经典的 POSIX 权限还不够,因为操作系统引入了许多机制来提供细粒度的控制和安全性。
访问控制列表
POSIX 权限提供了可以控制访问权限的三个组:所有者、组和其他所有人。另一方面,ACL 允许创建可能以多种方式定义的访问控制实体。这不是*NIX 入门,所以让我们开始深入了解。要检查 ACL,请启动终端会话,导航到包含目标文件的目录并键入:
ls -le foo.png
您应该会看到 POSIX 权限,然后是 ACL 规则的编号列表。如果您的帐户受到这些规则之一的影响,您可以按如下方式删除该规则:
sudo chmod -a# num foo.png
其中num
是违规规则的数字标识符。
文件标志
文件标志是另一个并行权限系统。再次使用终端,尝试:
ls -lO foo.png
注意:标志是小写字母 L,后跟大写字母 O。不要混淆数字 1 或 0 中的一个或另一个。
您将再次看到 POSIX 信息,后跟一个描述与相关文件有关的任何标志的字符串。您关心的标志是uchg
和schg
(分别表示用户不变性标志和系统不变性标志)。
您可以按如下方式摆脱这些标志:
sudo chflags nouchg foo.png
sudo chflags noschg foo.png
扩展属性
检查您的文件中的扩展属性,如下所示:
xattr -l $foo.png
删除所有扩展属性,如下所示:
sudo xattr -c $foo.png
系统完整性保护
系统完整性保护可能已将您的文件指定为“无根”。检查终端的状态:
ls -l@ foo.png
清除无根标志有点痛苦。通过恢复盘启动,打开终端,导航到您的文件并键入:
sudo xattr -d com.apple.rootless foo.png
我不是系统管理员,但至少其中一项应该涵盖您的问题,假设您已验证您的帐户具有 POSIX 权限并且该文件不只是通过 Finder 锁定(Command-I,查找小复选框在角落)。