Java applet无法在Safari 7下打开文件(Mac OS X 10.9)

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (76)

我们有一个使用Java applet操纵本地磁盘文件的网络应用程序。我们已经开发了相当长的一段时间,并且我们已经知道所有类型的applet可能会与现代操作系统和浏览器以及最新的Java版本和新的安全限制相关的问题。

昨天,苹果公司推出了全新的Safari浏览器(7.0),新的Mac OS 10.9 Mavericks。我在Safari 7 / Mac OS X 10.9下测试了我们的网络应用程序,以发现Safari 7(可能?)阻止从Java applet访问本地文件。

虽然小应用程序(使用有效的Thawte证书进行签名,并满足特定于Java 7u45的所有安全要求),但可以以完全访问本地文件系统的无限制模式运行(Java安全提示符表示),但尝试访问本地文件时,它会捕获fileNotFoundException :

java.io.FileNotFoundException: /Users/yury/Pictures/Paris 2012/L1050258.jpg (Operation not permitted)
    at java.io.FileInputStream.open(Native Method)
    at java.io.FileInputStream.<init>(FileInputStream.java:146)
    at com.trackntag.a.v.a(Unknown Source)

当从applet打开Java文件打开对话框时,它不显示任何文件,文件夹选择器中的文件夹没有任何图标(通常它们应该有它们)。当您回溯到根文件夹时,您可以看到顶层文件夹(bin,cores,dev,home等),但无法浏览它们。

在同一台计算机上(Java 7u45,Mac OS X 10.9),该applet可以访问本地文件并使用最新的Firefox 24 for Mac。与Safari 6和Mac OS X 10.8.5一样,更不用说在各种配置下的Linux和Windows机器了:访问本地文件没有问题。

综上所述,我必须得出结论,我们遇到了Safari 7特有的问题。

你对这个问题有什么想法吗?任何想法都不胜感激。

在Safari 7中有一个新的安全设置:安全/不安全模式(我认为它只适用于Java插件)。您可以允许Java插件以不安全模式工作,适用于单个网站或所有网站。在不安全模式下,小程序将无限制地访问本地文件系统。

看起来,此安全设置在Java自己的安全设置(限制/无限制访问)之上运行。

此设置可通过Safari偏好设置/安全选项卡/ Internet插件:管理网站设置(然后选择Java插件)。

因此,一旦我已经回答了我自己的原始问题,我宁愿改述一下:是否可以设置不安全模式或覆盖特定网站/ URL的安全模式而不要求用户设置此安全偏好?也许像苹果开发人员证书会有所帮助?

提问于
用户回答回答于

对于Safari 11:

  1. 转到Safari Preferences->Websites->Plug-ins, and select Java
  2. 在右侧,您可以看到“允许网站使用下面的设置使用此插件”的列表
  3. 现在选择网站
  4. 按住选项按钮,然后点击三个选项(询问,关闭,开启),您将看到附加选项'以安全模式运行' - 取消选中此选项。

用户回答回答于

我今天遇到了另一个Java应用程序的类似问题。我认为您可能需要将您的应用添加到此对话框中的“允许以下应用...”列表中(System Prefs -> Security & Privacy -> Accessibility):

扫码关注云+社区