无法在 macOS 上打开文件 - FileNotFoundException,不允许操作

Posted

技术标签:

【中文标题】无法在 macOS 上打开文件 - FileNotFoundException,不允许操作【英文标题】:Can't open file on macOS - FileNotFoundException, Operation not permitted 【发布时间】:2021-01-18 14:15:33 【问题描述】:

这是一个简单的程序:

new FileInputStream("/Users/me/Desktop/foo.png")

我正在尝试从 IntelliJ 运行它,我得到:

线程“主”java.io.FileNotFoundException 中的异常:/Users/me/Desktop/foo.png(不允许操作)

unix 权限是通常的rw-r--r--。这与 macOS 的额外安全性有关。

现在如何在 macOS 上的 Java 程序中打开文件?

这是 macOS 11.0 beta (Big Sur)。也许它也发生在 11.0 之前;我不知道。

【问题讨论】:

您可能遇到了Transparency Consent and Control (TCC)。我会尝试在系统偏好设置->安全和隐私面板->隐私选项卡中授予对 IntelliJ 的全盘访问权限。 感谢 Gordon,它帮助解决了这个问题。 【参考方案1】:

您遇到了特定于 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 信息,后跟一个描述与相关文件有关的任何标志的字符串。您关心的标志是uchgschg(分别表示用户不变标志和系统不变标志)。

您可以按如下方式摆脱这些标志:

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,查找角落里的小复选框)。

【讨论】:

超级有用的答案,因为我总是忘记所有这些不同的文件属性/标志。但在这种情况下,我相信 IntelliJ 在“沙箱”中运行。我使用 IDE 中的文件打开对话框在桌面中打开了一个文件,然后错误就消失了。我认为文件打开对话框允许应用程序在沙箱之外读取文件。我现在正在寻找一种方法来重置该权限,以进行测试。重启 IntelliJ 并没有重置它。

以上是关于无法在 macOS 上打开文件 - FileNotFoundException,不允许操作的主要内容,如果未能解决你的问题,请参考以下文章

在 macOS 上自动打开目录的适当权利

教程篇macOS 10.14 MAC应用无法打开或文件已损坏处理方法

无法在 Mac 上使用 qt 应用程序打开文件

macOS Catalina 上的应用程序“无法打开,因为无法验证其完整性”

macOS Catalina 已损坏无法打开解决办法

premiere无法打开磁盘上的文件,怎么办?