我们有一个 Java 小程序,用户可以使用它将成像数据上传到我们的数据库,我们使用 Oracle 的 deployJava.js 来启动它。最近,一些用户,包括我的一位同事,发现自己不断地重定向到 Oracle 的 Java 安装页面,即使安装了 Java。
我试图在我同事的电脑上调试它并发现以下内容:
她安装了 Java 8,但没有安装 Java 7。(但是,删除以前的 Java 安装并仅安装 Java 8 不足以重现此问题。)
此问题发生在 Internet Explorer 11 以及当前的 Chrome 和 Firefox 版本中;允许插件在网站上运行后,Chrome 和 Firefox 在重新加载页面和后续访问后工作(即使使用“允许一次”),而临时或永久允许在 Internet Explorer 中没有任何区别。对于有同样问题的其他用户来说,事情突然开始工作的行为是无法重现的。
这与用户代理字符串错误JDK-8026474 无关,我们使用已修复此问题的当前版本的 deployJava.js。
在 Internet Explorer 中打开兼容模式没有任何区别。
在尝试在 Javascript 中对此进行调试时,问题似乎出在函数 getJREs 中:
getJREs: function() {
var list = new Array();
if (this.isPluginInstalled()) {
var plugin = this.getPlugin();
var VMs = plugin.jvms;
for (var i = 0; i < VMs.getLength(); i++) {
list[i] = VMs.get(i).version;
}
} else {
var browser = this.getBrowser();
if (browser == 'MSIE') {
if (this.testUsingActiveX('1.7.0')) {
list[0] = '1.7.0';
} else if (this.testUsingActiveX('1.6.0')) {
list[0] = '1.6.0';
} else if (this.testUsingActiveX('1.5.0')) {
list[0] = '1.5.0';
} else if (this.testUsingActiveX('1.4.2')) {
list[0] = '1.4.2';
} else if (this.testForMSVM()) {
list[0] = '1.1';
}
} else if (browser == 'Netscape Family') {
this.getJPIVersionUsingMimeType();
if (this.firefoxJavaVersion != null) {
list[0] = this.firefoxJavaVersion;
} else if (this.testUsingMimeTypes('1.7')) {
list[0] = '1.7.0';
} else if (this.testUsingMimeTypes('1.6')) {
list[0] = '1.6.0';
} else if (this.testUsingMimeTypes('1.5')) {
list[0] = '1.5.0';
} else if (this.testUsingMimeTypes('1.4.2')) {
list[0] = '1.4.2';
} else if (this.browserName2 == 'Safari') {
if (this.testUsingPluginsArray('1.7.0')) {
list[0] = '1.7.0';
} else if (this.testUsingPluginsArray('1.6')) {
list[0] = '1.6.0';
} else if (this.testUsingPluginsArray('1.5')) {
list[0] = '1.5.0';
} else if (this.testUsingPluginsArray('1.4.2')) {
list[0] = '1.4.2';
}
}
}
}
if (this.debug) {
for (var i = 0; i < list.length; ++i) {
log('[getJREs()] We claim to have detected Java SE ' + list[i]);
}
}
return list;
}
在我同事的 Internet Explorer 计算机上,“this.isPluginInstalled()”检查失败,因此该函数进入回退状态,没有检查 Java 8。我尝试创建 deployJava 的本地副本并手动添加检查,但是没有任何效果-IE仍然失败。
这是我为评估问题而编写的测试页面:
<html>
<head><title>DeployJava test</title></head>
<body>
<script src="https://www.java.com/js/deployJava.js"></script>
<script>
document.write("Has Java version 1.6: " + deployJava.versionCheck("1.6") + "<br\>");
document.write("Has Java version 1.7: " + deployJava.versionCheck("1.7") + "<br\>");
document.write("Has Java version 1.8: " + deployJava.versionCheck("1.8") + "<br\>");
document.write("Installed JREs: " + deployJava.getJREs() + "<br\>");
document.write("Firefox version: " + deployJava.firefoxJavaVersion + "<br\>");
document.write("ActiveX version: " + deployJava.testUsingActiveX("1.8.0") + "<br\>");
document.write("MIME type version: " + deployJava.testUsingMimeTypes("1.8") + "<br\>");
document.write("Plugin Array version: " + deployJava.testUsingPluginsArray("1.8.0"));
</script>
</body>
</html>
在我的电脑上,这会在 IE 11 中产生以下结果:
具有 Java 版本 1.6:false 具有 Java 版本 1.7:false 具有 Java 版本 1.8:true 已安装的 JRE:1.8.0_25 Firefox 版本:null ActiveX 版本:false MIME 类型版本:false 插件数组版本:false
在遇到此问题的同事的计算机上,使用相同的 IE 和 Java 版本,它会产生:
具有 Java 版本 1.6:false 具有 Java 版本 1.7:false 具有 Java 版本 1.8:false 已安装的 JRE:Firefox 版本:null ActiveX 版本:false MIME 类型版本:false 插件数组版本:false
我还能尝试什么的想法?
更新
我们目前对造成这种情况的最佳猜测是 Java 7 安装在安装 8 时没有正确卸载,导致浏览器插件出现故障。通过从计算机上卸载所有 Java 安装并仅重新安装 Java 8 的暴力解决方案,我们已经能够为遇到此问题的两个用户解决此问题。