漏洞分析 | Apache Struts文件上传漏洞(CVE-2024-53677)

漏洞概述

Apache Struts是美国阿帕奇(Apache)基金会的一个开源项目,是一套用于创建企业级Java Web应用的开源MVC框架。

近期,网宿安全演武实验室监测到Apache Struts在特定条件下,存在文件上传漏洞(网宿评分:高危;CVSS 3.0 评分:8.1):

攻击者可以操纵文件上传参数来实现路径遍历,在某些情况下,这可能导致恶意文件上传。目前该漏洞POC状态已在互联网公开,建议客户尽快做好自查及防护。

受影响版本

Struts 2.0.0 - 2.3.37(EOL)

Struts 2.5.0 - 2.5.33(EOL)

Struts 6.0.0 - 6.3.0.2

前置知识

在 Struts 2 中,有一个重要特性——值栈,它帮助我们能够轻松访问 Action 类中的属性。

而其工作原理可以简单理解为,当我们访问一个Action时,Struts 2就会创建该 Action 类的实例并将它推送到值栈的顶部。参照官方wiki(https://cwiki.apache.org/confluence/display/WW/OGNL+Basics)可知,使用top关键字即可访问栈顶对象。

示例代码如下:

MyAction.java

package com.struts2;
import com.opensymphony.xwork2.ActionSupport;
public class MyAction extends ActionSupport {
    private String message;
    @Override
    public String execute() throws Exception {
        message = "Hello";
        return SUCCESS;
    }
    public String getMessage() {
        return message;
    }
}

test.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="s" uri="/struts-tags" %>
<html>
<body>
<h3>值栈访问示例:</h3>
<div>
  <p>当前栈顶为(使用[0].top): <s:property value="[0].top" /></p>
  <p>当前栈顶为(使用top): <s:property value="top" /></p>
  <p>从栈顶查找MyAction属性(使用 [0].top): <s:property value="[0].top.message" /></p>
  <p>从栈顶查找MyAction属性(使用 top): <s:property value="top.message" /></p>
</div>
</body>
</html>

struts.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
        "http://struts.apache.org/dtds/struts-2.5.dtd">
<struts>
    <package name="default" extends="struts-default">
        <action name="MyAction" class="com.struts2.MyAction">
            <result name="success">/test.jsp</result>
        </action>
    </package>
</struts>

结果如下:

漏洞分析

根据官方披露的信息(https://cwiki.apache.org/confluence/display/WW/S2-067)可知:

后续处理上传的拦截器将变更为org.apache.struts2.interceptor.ActionFileUploadInterceptor
其与org.apache.struts2.interceptor.FileUploadInterceptor的差别在于,直接将接收的文件通过 action.withUploadedFiles(acceptedFiles) 传递给 Action

而不是将文件绑定到 Action 的属性中。

那么可以猜测漏洞利用是通过参数绑定实现的,不过CVE-2023-50164以后,无法再借助大小写对set的参数进行覆盖。这时可以结合上文所了解的值栈知识突破,即访问值栈栈顶对象本身并修改其属性。

但后续调试时发现卡在了这一步:

protected boolean isAccepted(String paramName) {
    AcceptedPatternsChecker.IsAccepted result = acceptedPatterns.isAccepted(paramName);
    if (result.isAccepted()) {
        return true;
    } else if (devMode) { // warn only when in devMode
        LOG.warn("Parameter [{}] didn't match accepted pattern [{}]! See Accepted / Excluded patterns at\n" +
                        "https://struts.apache.org/security/#accepted--excluded-patterns",
                paramName, result.getAcceptedPattern());
    } else {
        LOG.debug("Parameter [{}] didn't match accepted pattern [{}]!", paramName, result.getAcceptedPattern());
    }
    return false;
}

这里可以采用另一种方式:

成功修改文件名。

漏洞复现

这里设置上传路径为/test/a

filePath = ServletActionContext.getServletContext().getRealPath("/") + "test/a/";

正常上传:

非正常上传:

修复方案

目前厂商已发布升级补丁以修复漏洞:https://struts.apache.org/core-developers/file-upload

产品支持

网宿WAAP全站防护-云WAF已支持对该漏洞利用攻击的防护,并持续挖掘分析其他变种攻击方式和各类组件漏洞,第一时间上线防护规则,缩短防护“空窗期”。

除此之外,建议通过Bot管理产品来增强对新漏洞的防护,在大多数情况下,企业遇到的0day不是针对性的定向攻击,而是广泛的自动化扫描,攻击者发现一个0day/新漏洞之后,通常会先使用自动化工具进行全网扫描踩点,发现存在漏洞的网站再进一步攻击,通过部署Bot管理,可以有效阻断自动化扫描工具的访问,从而避免攻击面的暴露。

Apache Struts 2的一个严重安全漏洞CVE-2024-53677)是由于其文件上传功能存在不当限制,攻击者可以通过此漏洞上传恶意脚本并执行。为了检查你的Struts 2项目是否存在该漏洞,可以执行以下操作: 1. **更新Struts版本**: 首先,检查项目中的Struts版本是否低于2.5.18,因为这个版本受到了影响。如果版本过低,立即升级到最新安全补丁。 ```bash mvn dependency:tree | grep struts2-core ``` 确认Struts核心库的版本,然后访问Struts官网或查找公告确认是否需要升级。 2. **审查上传配置**: 查看应用的Web资源目录(如`web-inf/classes/struts-default.xml`或`webapp/WEB-INF/web.xml`),检查`<form-bean>`元素中的`<result>`标签。 如果存在类似以下的配置,可能存在风险: ```xml <result name="input">/YourAction/upload?_charset_=UTF-8</result> ``` 这里的关键点在于上传结果直接指向了特定的Action,而非经过某种过滤或验证。 3. **代码审查**: 寻找Action类中处理文件上传的部分,特别是那些接收和处理`MultiPartFormDataInput`的地方。查看是否有对文件类型、大小等进行有效的校验。 ```java @Override protected ActionForward executeInternal(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { MultiActionForm multiActionForm = (MultiActionForm) form; MultiPartFormDataInput input = (MultiPartFormDataInput) multiActionForm.getMultiPart(); // ... 检查文件是否满足条件 } ``` 4. **使用静态分析工具**: 可以利用一些静态分析工具(如OWASP Dependency Check、SpotBugs等)帮助检测代码中的潜在漏洞,它们可能会发现未修复的文件上传漏洞。 注意:如果你不确定如何操作或代码复杂难以排查,建议寻求专业的安全审计服务,避免自行处理导致更大的风险。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值