当前位置: 首页 > news >正文

Java 应用程序已被安全阻止 —— 原因分析与解决方案

一、问题现象

在启动 Java KVM / Java Web Start 应用时,弹出如下提示:

应用程序已被 Java 安全阻止
出于安全原因,应用程序现在必须满足“高”或“非常高”安全设置的要求或属于“例外站点列表”的一部分才能允许运行。

名称:com.kvm.viewer.Viewer
位置:https://***
原因:您的安全设置已阻止已签名的应用程序运行

此时:

  • 没有“继续 / 运行”按钮
  • 无法通过自动化(Playwright、PyJAB 等)绕过
  • 应用直接被终止

二、这是 Java 安全机制的“硬阻断”

这不是程序 bug,也不是自动化工具的问题,而是 Java 的安全策略主动拦截。

该提示意味着:

Java 在 JVM 启动之前就拒绝了该应用

一旦出现这个窗口:

  • JVM 不会创建
  • Java Accessibility Bridge 不会加载
  • 后续任何 UI 自动化都无效

三、触发该问题的直接原因

从 Java 官方安全模型角度,触发条件主要有以下几类:

1. 应用签名不被信任(最核心原因)

  • 应用虽然“已签名”
  • 但签名证书:
    • 过期
    • 自签名
    • 使用弱算法(SHA1)
    • 证书链不完整
  • Java 8u51 以后 默认不再信任此类签名

结论:“已签名 ≠ 被信任”

2. 使用 IP 地址 + HTTPS 访问

Java 安全策略中:

  • HTTPS + IP 地址,不被视为“可信主机名”
  • 证书中的 CN / SAN 与 IP 不匹配

Java 会认为:存在中间人风险(MITM)

3. 安全级别为 High / Very High

在 Java 控制面板中:

  • High / Very High:
    • 禁止运行未在白名单中的应用
    • 不会弹“是否继续”
    • 直接阻断

4. 自动化启动方式加重了风险判定(次要但常见)

在以下场景更容易被直接阻止:

  • 浏览器自动下载 .jnlp
  • 自动执行 Java Web Start
  • 无明显人工交互

Java 会更倾向于走“保守策略”。


四、为什么有时“能点继续”,有时却被直接阻止?

这是很多人困惑的点,关键在于拦截发生的阶段不同

阶段行为
弹出“安全警告”软拦截(允许用户确认)
显示“已被 Java 安全阻止”硬拦截(JVM 未启动)

一旦进入“硬拦截”,任何自动化手段都无效


五、推荐的解决方案

方案一:使用 Exception Site List

这是官方推荐、最稳妥的方式。

操作步骤

  1. 打开 Java 控制面板
  2. 进入 Security
  3. 安全级别设置为:High
  4. 点击 Exception Site List
  5. 添加访问地址(示例):https://<*******>

效果:

  • 不再出现“已被安全阻止”
  • Java 恢复弹出正常安全确认
  • 自动化可继续接管

方案二:部署自签 CA 或使用可信证书

适合长期方案:

  • 给 Java 应用重新签名
  • 使用企业 CA 或可信证书
  • CN / SAN 与访问域名匹配

优点:

  • 不需要 Exception List
  • 符合安全规范

缺点:

  • 成本高
  • 需要供应商支持

方案三:绕过浏览器,直接 javaws 启动

自动化场景建议:

  1. 浏览器仅负责下载.jnlp
  2. 使用命令行启动:
javaws -silent viewer.jnlp

优点:

  • 避免浏览器安全链
  • Java 更容易进入“可交互安全提示”状态
  • 兼容 UI 自动化

“应用程序已被 Java 安全阻止”不是弹窗问题,而是 JVM 启动权限问题。 解决问题的关键不在自动化,而在 Java
安全信任链的正确配置。

http://www.jsqmd.com/news/249629/

相关文章:

  • AI三大黑科技:MCP、RAG、Agent,让AI从“工具“变“助手“
  • 【必藏】LangGraph实战教程:构建智能笑话生成评估工作流
  • “特种橡胶”高端领域的性能先锋,赋能极端环境与精密制造
  • 程序员警惕!AI已斩断成长路径,但真正的护城河在这里【深度收藏】
  • 瑞芯微(EASY EAI)RV1126B 安全帽检测
  • 反激式开关电源设计方案,12V6A输出,有完整原理图,PCB工程文件,BOM表,可直接使用
  • 钥匙启动车辆改装为一键启动或手机远程启动提升便利性
  • 收藏!一文读懂Agent思维链技术:从Claude到Gemini,为什么说这是Agent性能提升的关键?
  • kafka C++ 和 java端计算分区ID不一致排查
  • 收藏!2026年程序员必看:为什么‘只会写代码‘正在被AI淘汰
  • 为什么你的大模型总在胡说八道?RAG技术彻底解决幻觉问题(必学收藏)
  • 【技术干货收藏】智能体规划模式:从“被动执行“到“主动运筹“,AI能力质的飞跃!
  • 基于视觉大模型的实时监控系统技术实现解析
  • 货车手机远程启动一键启动无钥匙进入哪个功能更实用
  • SIEMENS西门子杯,西门子六部十层电梯程序,跑分可以西门子-2021-初赛电梯最终版
  • 震惊!“前端已死“刷屏,真相是...程序员必看:如何从写代码到写思路(必收藏)
  • 2026必备!9个AI论文写作软件,自考学生轻松搞定毕业论文!
  • 2026程序员生存指南:当“斩杀线“逼近,你的代码正在被AI替代,收藏这篇救命攻略
  • 【必藏】200行代码从零实现LLM:破解大模型黑盒,告别只会调用API的日子
  • CUDA统一内存(UVM)完整演进历程-软件篇
  • 微信小程序版「死了么APP」,它来了
  • 从“死流程“到“活资产“:五步构建AI原生应用新架构【干货收藏】
  • 收藏必看!大模型推理新范式:一次思考两次回答,大幅提升思维链质量与推理效率
  • 【必藏】AI Agent实战:打造能自主决策的“数字员工“,架构师必看!
  • PoE 延长器:突破 PoE 距离限制,优化网络灵活部署方案
  • 【必读收藏】工具使用模式:给智能体装上“超能力“,让它真正走进现实!
  • **软件配置项(SCI)的组成** 软件配置项(Software Configuration Item, SCI)是软件配置管理中的基本单位
  • 必藏!让Agent真正“能干活“的Agent Skills全解析,从入门到实战
  • Arcgis导出数据时出错,空间参考z值不匹配(已解决)
  • 显卡市场四强格局解析:技术革新驱动品牌竞争新阶段