Apache Struts2开发模式漏洞解析与修复

news2024/9/21 4:31:07

1.引言

在现代Web应用开发中,Apache Struts2是一个广泛使用的MVC框架。然而,当一些开发方便的功能错用在生产环境时,会导致严重的安全隐患。本文将详细解析Struts2开发模式(devMode)带来的安全风险及其修复方法。

2.什么是Struts2开发模式?

开发模式(devMode)是Apache Struts2框架中的一个特性,旨在帮助开发者更轻松地调试和开发应用程序。一旦开启这个模式,Struts2会提供更加详细的调试信息,以便快速定位和解决问题。通常,在struts.properties文件中可以设置:

struts.devMode=true

3.漏洞描述

虽然开发模式在开发阶段非常有用,但它在生产环境中却是个严重的安全漏洞。具体风险包括:

1. OGNL(Object Graph Navigation Language)注入:开发模式允许通过OGNL控制台执行任意表达式,这可能被攻击者利用进行代码注入和执行。
2. 内部信息泄露:开发模式会公开更多的调试信息,展示更详细的错误堆栈和内部配置,这为攻击者提供了更丰富的攻击面。
3. 未授权访问:打开的OGNL控制台可能被未授权用户访问,执行恶意代码或操作。

4.漏洞影响

如果在生产环境中启用了开发模式,攻击者可能会:

1.获取服务器内的敏感数据
2.执行任意服务器端代码
3.占用系统资源,导致拒绝服务(DoS)攻击

5.诊断过程

在诊断这个漏洞时,我们通过访问 http://yourserver/***/struts/webconsole.html URL,发现了OGNL控制台。这本应在开发环境中才能访问的工具,却在生产环境暴露出来。下图为访问时的情况,可以看到这是Struts2的OGNL控制台界面:

执行一些OGNL表达式验证漏洞的存在,例如:

简单数学运算:
在命令行输入框中输入:

1 + 1

成功执行后,控制台显示:

Welcome to the OGNL console!
1 + 1
2
:->

这些简单的例子足以说明在生产环境中启用开发模式,将引起执行任意代码的高度风险。

6.修复方法

1. 禁用开发模式
首先,确保生产环境中的struts.properties文件禁用devMode:

struts.devMode=false


2. 重启服务器
更改配置文件后,请务必重启Web服务器以确保新设置生效。

3. 移除调试代码
确认代码库中没有多余的调试代码或控制台访问逻辑。

7.安全实践建议

为防止类似安全问题的出现,建议:

1.严格环境区分:确保开发、测试和生产环境配置分离,且生产环境严格遵守安全配置。
2.定期安全审计:定期对应用进行安全扫描,识别和修复潜在安全漏洞。
3.最小权限策略:严格控制谁可以访问和修改配置文件,实行最小权限策略,确保配置文件仅由授权人员可操作。

8.结语

现代Web框架在开发过程中提供了很多便利的调试工具,但使用时必须严格区分开发环境和生产环境。一丁点疏忽都会带来灾难性的安全后果,希望本文能帮助你们识别并修复 Struts2 开发模式的安全漏洞,确保生产环境的安全。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2091463.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vim常用快捷键问答

vim的光标位置操作快捷键有哪些?怎样记忆它们? 在 Vim 中,光标位置的操作快捷键非常重要,可以帮助你更高效地编辑文本。下面是一些常用的光标位置操作快捷键: 基本移动 h:光标左移一个字符j:光…

【吊打面试官系列-Redis面试题】Redis 是单进程单线程的?

大家好,我是锋哥。今天分享关于 【Redis 是单进程单线程的?】面试题,希望对大家有帮助; Redis 是单进程单线程的? Redis 是单进程单线程的,redis 利用队列技术将并发访问变为串行访问,消除了传统…

Linux-vim

文章目录 vi和vimvim的基本概念vim的基本操作vim正常模式命令集插入模式从插入模式切换为命令模式移动光标删除文字复制替换撤销上一次操作更改跳至指定的行 vim末行模式命令集列出行号跳到文件中的某一行查找字符保存文件推出vim vi和vim vi/vim的区别简单点来说,…

【初学人工智能原理】【14】机器学习:最后一节课也是第一节课(完结)

前言 本文教程均来自b站【小白也能听懂的人工智能原理】,感兴趣的可自行到b站观看。 代码及工具箱 本专栏的代码和工具函数已经上传到GitHub:1571859588/xiaobai_AI: 零基础入门人工智能 (github.com),可以找到对应课程的代码 正文 随着…

制作 Docker 镜像

目录 1 docker镜像介绍 1.1 docker的镜像结构 1.2 镜像运行的基本原理 1.3 镜像获得方式 2 构建 docker 镜像 Dockerfile 2.1 Dockerfile 基础参数介绍 2.2 实现参数功能示例 2.2.1 FROM LABEL COPY 2.2.2 ADD 2.2.3 ENV 和 CMD与ENTRYPOINT 2.2.3.1 CMD的替代性 2.2.3.2 EN…

使用3D数字人做视频

用3D数字人做视频 漂亮精致 3D数字人定制4 动作流畅、音乐上的表现 thatgirl 支持私人定制模型 你愿意捐献所有的财产吗 想搭建这样的数字人的请和我们联系 使用3D数字人做视频https://www.jinshuangshi.com/forum.php?modviewthread&tid248 (出处: 金双石科技)

利用session.upload_progress执行文件包含

1.session.upload_progress的作用: session.upload_progress最初是PHP为上传进度条设计的一个功能,在上传文件较大的情况下,PHP将进行流式上传,并将进度信息放在Session中(包含用户可控的值),即…

Ethercat设备数据 转IEC61850项目案例

目录 1 案例说明 1 2 VFBOX网关工作原理 1 3 准备工作 2 5 设置网关采集ETHERCAT数据 5 6 用IEC61850协议转发数据 7 7 网关使用多个逻辑设备和逻辑节点的方法 9 8 安装NPCAP 10 9 案例总结 11 1 案例说明 设置网关采集EtherCAT设备数据把采集的数据转成IEC61850协议转发给其…

08:Logic软件原理图添加元件

1.导入外部库文件 2.添加元件

Veeam Data Platform 12.2 发布下载,新增功能概览

Veeam Data Platform 12.2 发布下载,新增功能概览 面向混合云和多云的 云端、虚拟和物理环境 备份和恢复 监控和分析 恢复编排 请访问原文链接:https://sysin.org/blog/veeam-data-platform/,查看最新版。原创作品,转载请保留出…

飞致云开源社区月度动态报告(2024年8月)

自2023年6月起,中国领先的开源软件公司FIT2CLOUD飞致云以月度为单位发布《飞致云开源社区月度动态报告》,旨在向广大社区用户同步飞致云旗下系列开源软件的发展情况,以及当月主要的产品新版本发布、社区运营成果等相关信息。 飞致云开源大屏…

计算机组成原理:实验三数据通路组成实验

一、实验目的 1.将双端口通用寄存器堆和双端口存储器模块联机; 2.进一步熟悉计算机的数据通路; 3.掌握数字逻辑电路中故障的一般规律,以及排除故障的一般原则和方法; 4.锻炼分析问题与解决问题的能力,在出现故障的…

Windows 10远程桌面连接设置

0 Preface/Foreword 0.1 Remote desktop (远程桌面) Remote Desktop lets you connect to or control this PC from a remote device by using a Remote Desktop client (available for Windows, Android, iOS and macOS). Youll be able to work fro…

15年让爱轮回

15年前,运巧的命运齿轮因一位记者的稿件悄然转动,运巧这个名字,真的是命运的巧合,把她和邦尔骨科连接在了一起,她的人生轨迹因一家医院的善举发生了改变。那时的她,面临生活的重重困境,求学之路…

通义 AI 再次颠覆创作体验:一句话即可生成PPT

🆕通义 AI 再次颠覆创作体验:一句话即可生成PPT 🎉 最近,科技圈再度被通义 AI 的最新功能刷屏!8月30日,通义网页版正式上线了让无数办公族翘首以盼的“PPT 创作”功能。这一革新功能不仅为内容创作者带来了…

制作人偶动画Character Animator

每个人都可以通过表演开始制作动画。无需具备专业的操控知识。 入门模式提供示例人偶,可帮助您快速创建动画。选择人偶或导入人偶,然后添加或录制语音。 每个示例人偶都有一个完备的“控件”面板,其中包含多种姿势和情绪。 您可以通过选择“自…

【TDesign】如何修改CSS变量

Tdesign的组件想通过style定义样式没效果, 可以通过组件api文档修改, 组件提供了下列 CSS 变量,可用于自定义样式。 比如Cell, https://tdesign.tencent.com/miniprogram/components/cell?tabapi 提供了: –td-cell-left-icon-color 图标颜色 –td-cell…

【每日一题】【想通后的诈骗题】Wakey Wakey 牛客挑战赛76 A题 C++

牛客挑战赛76 A题 Wakey Wakey 题目背景 牛客挑战赛76 题目描述 样例 #1 样例输入 #1 2 2 3 2 10000 100000 2333样例输出 #1 1 2014备注 1 ≤ T ≤ 10 1\le T\le 10 1≤T≤10 1 ≤ n , m ≤ 1 0 5 1\le n,m \le 10^5 1≤n,m≤105 1 ≤ p ≤ 1 0 9 1\le p \le 10^9 1…

干货分享|分享一款自己常用的桌面整理神器 WPS桌面整理

问题:下面两张图是使用WPS桌面整理前后的对比。 使用方法: 1.打开WPS 2.点击桌面右下角WPS办公助手--选择桌面整理--整理桌面 注:桌面整理后,可以通过右键点击格子并根据个人喜好进行编辑。操作简便,大家自行尝试和探索…

线性代数|机器学习-P31完成一个秩为1的矩阵

文章目录 1. 大纲2. 填充秩1矩阵2.1 举例2.2 二分图 3. 循环卷积矩阵 1. 大纲 给定一个秩为1的矩阵A,m行,n列,如果在矩阵A中给定mn-1 个非零的值,请问如何填充这个矩阵A,使得矩阵A 填满?卷积和循环卷积矩阵&#xff0…