Hack The Box-PermX

news2024/9/21 21:44:38

总体思路

CVE-2023-4220->敏感信息收集->符号链接攻击

信息收集&端口利用

nmap -sSVC permx.htb
Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-07-07 21:16 EDT
Nmap scan report for permx.htb
Host is up (0.24s latency).
Not shown: 998 closed tcp ports (reset)
PORT   STATE SERVICE VERSION
22/tcp open  ssh     OpenSSH 8.9p1 Ubuntu 3ubuntu0.10 (Ubuntu Linux; protocol 2.0)
| ssh-hostkey: 
|   256 e2:5c:5d:8c:47:3e:d8:72:f7:b4:80:03:49:86:6d:ef (ECDSA)
|_  256 1f:41:02:8e:6b:17:18:9c:a0:ac:54:23:e9:71:30:17 (ED25519)
80/tcp open  http    Apache httpd 2.4.52
|_http-server-header: Apache/2.4.52 (Ubuntu)
|_http-title: eLEARNING
Service Info: Host: 127.0.1.1; OS: Linux; CPE: cpe:/o:linux:linux_kernel

Service detection performed. Please report any incorrect results at https://nmap.org/submit/ .
Nmap done: 1 IP address (1 host up) scanned in 19.17 seconds

目标只开放了80端口,那么在访问的同时先上一波目录扫描和子域名扫描

ffuf -c -u 'http://permx.htb' -H 'host: FUZZ.permx.htb' -w /usr/share/seclists/Discovery/DNS/subdomains-top1million-5000.txt -fc 301,302 -mc all
dirsearch -u http://permx.htb

在这里插入图片描述

在这里插入图片描述

经过大致查看后,该网站是一个学习网站,用于报名一些网上课程等等,这里先查看刚刚扫描的结果

在这里插入图片描述

在这里插入图片描述

有一个lms子域名,加入进hosts文件后访问之

在这里插入图片描述

很明显是一个Chamilo框架的界面

Chamilo是一款免费的开源LMS,支持设计和进行远程课程在线培训项目。此外,许多教育工作者选择Chamilo来进行现场培训课程。Chamilo安全可靠,可提供50多种语言版本

在exploit-db中搜索相关漏洞情况

在这里插入图片描述

CVE-2023-4220

发现最新的漏洞需要通过验证才行,在浏览器中搜索漏洞后,发现存在CVE-2023-4220

在这里插入图片描述

阅读文章后,发现其存在的是未经身份认证的文件上传漏洞,存在于/main/inc/lib/javascript/bigupload/inc/bigUpload.php文件

访问界面后,确实存在一个bigUpload.php文件,但是浏览器上不能查看代码内容

在这里插入图片描述

利用文章里边的poc上传PHP shell

在这里插入图片描述

在files路径下访问该文件

在这里插入图片描述

将shell反弹到本地进行下一步

在这里插入图片描述

经过测试后发现www-data用户不存在能够执行其他提权命令的权限,考虑是否存在信息泄露方面的点

在lms子域的源码中,能够看到有其他几个界面可以访问

在这里插入图片描述

发现下方有一个app/upload

在这里插入图片描述

但是查看后里面并没有内容

返回上一级后,发现有一个config文件夹,进入查看

在这里插入图片描述

敏感信息收集

发现其中有一个configuration.php,虽然在浏览器不能访问,但是可以在shell中查看

在这里插入图片描述

有一段数据库的用户名和密码:chamilo/03F6lY3*******

查看本地端口开放情况

在这里插入图片描述

数据库的端口确实开着,尝试连接

在这里插入图片描述

在这里插入图片描述

查看user表中的内容

在这里插入图片描述

发现就两个用户admin和anon,但是查看passwd文件后,发现anon用户并不在可以登录的列表中,只有一个mtz用户可以登录

在这里插入图片描述

那么尝试使用之前拿到的密码登录mtz用户

在这里插入图片描述

啊哈,果然是这样

查看当前用户的权限

在这里插入图片描述

可以以任意身份执行/opt/acl.sh文件,那么先查看文件作用

在这里插入图片描述

分析代码,发现其主要功能是更改文件所有权限,但是要求必须在/home/mtz目录下,并且目标路径中不能带有…(防止逃逸)

查看mtz目录下有什么文件

在这里插入图片描述

符号链接攻击

这里想到可以使用符号链接攻击

根据该脚本,其可以修改位于/home/mtz文件夹下的所有文件权限,那么可以符号链接将根目录映射到mtz下来执行攻击

在这里插入图片描述

这里将根目录的所有文件通过符号链接(类似于快捷方式?)映射到mtz文件夹内

因此我们可以修改任意一个文件的权限,那么想到修改shadow文件,通过重写密码的方式获得root权限

不过每隔一段时间符号链接脚本以及文件权限会被重置,需要重新运行命令

在这里插入图片描述

在这里插入图片描述

现在具有对shadow文件的更改权限,那么重新生成一段密码为B3rry的密码,然后将其覆盖

openssl passwd -6 B3rry

在openssl命令中,-6选项与passwd子命令一起使用时,用于生成使用SHA-512算法的密码散列。这个命令通常用于生成或验证与Linux系统上的/etc/shadow文件或其他密码存储系统兼容的密码散列

echo 'root:$6$4mXMUzMb9F48k1B6$XxnsvpWE3Q46pPYzesxlJ92LuxDzcfbv0terDnwzaZogCPBLbnwBRYgNVjXIuK4OccfPqi9Wv1vfsQbVfgF9w1:19742:0:99999:7:::' > /etc/shadow

在这里插入图片描述

此时root密码已经被更改为B3rry,直接登录即可

在这里插入图片描述

发现其目录下有重置权限的脚本

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

leetcode:编程基础0到1

文章目录 交替合并字符串str.length();StringBuilder类型 ,toString()append() ,chatAt()题目描述 交替合并字符串 str.length(); 输出字符串str的长度 StringBuilder类型 ,toString() append() ,chatAt() 题目描述 class Solution {public String …

位置编码的具体计算方式(公式解释)

公式 (10.6.2) 描述了位置编码的具体计算方式,这种位置编码基于正弦和余弦函数,用于在自注意力机制中引入位置信息。下面我们详细解释公式和代码。 公式 (10.6.2) 公式 (10.6.2) 的目的是为输入序列中的每个词元添加一个位置编码,以保留序列…

下载程序到仿真

第一步,新建工程 第二步,设备组态 第三步,地址分配 需要注意的是,分配地址的范围,是CPU决定的。 关于常见数据类型 下载与仿真 一般安装好博图会自带。 PLCSIM/PLCSIM Advanced PLCSIM普通仿真 PLCSIM Advanced高级…

绝地求生PUBG没有开始游戏按钮的解决办法

绝地求生是一款特别热门的战术竞技型射击类游戏,游戏中玩家需要在游戏地图上收集各种资源,并在不断缩小的安全区域内持武器对抗其他玩家,让自己生存到最后。当游戏最后场上只剩下一支队伍的时候即可获得游戏胜利。然而一些玩家在游玩绝地求生…

MICCAI 2024Centerline Boundary Dice Loss for Vascular Segmentation

MICCAI 2024 Centerline Boundary Dice Loss for Vascular Segmentation MICCAI 2024Centerline Boundary Dice Loss for Vascular Segmentation中心线边界Dice损失用于血管分割**摘要**:1. 引言相关工作: 2. 方法预备知识Dice的变化 3 实验3.1 数据集3.2 设置3.3 结…

autocad软件许可优化解决方案

Autocad软件介绍 Autodesk 是世界领先的设计软件和数字内容创建公司,用于建筑设计、土地资源开发、生产、公用设施、通信、媒体和娱乐。始建于 1982 年,Autodesk 提供设计软件、Internet 门户服务、无线开发平台及定点应用,帮助遍及 150 多个…

uniapp 表格,动态表头表格封装渲染

1.接口表格数据: {"headers": [{"label": "实例名","name": "v1","order": 1,"hide": false,"dateTypeValue": null},{"label": "所属科室","name&quo…

【Java伴学笔记】Day-01 命令行|环境|编译解释运行|Java的相关分支|Java的特性|字面量

一、关于命令行 图形化界面的缺点 需要加载图片等一系列资源 效率较低 命令行 CMDMicrosoft Learn-CMDWindows CMD常用命令大全(值得收藏) 二、环境 什么是JDK JDK是Java Development Kit的缩写,意为Java开发工具包。它是一个用于开发Java应用…

分类下两列一组统计

表格 A 列是分类,后面是 2N 个 key-value 列 ABCDEFG1CountryLabel1Count1Label2Count2Label3Count32USA10B9C83USD9C8A74USC8D7B65USA7C6B56CAA10B9C87CAD9C8A78CAC8D7B69INA10C9B810IND9A8B711INA8D7B6 需要对分类、key 分组,对 value 求和&#xff…

【Qt】Qt Creator初使用

目录 一. 创建新项目 二. 认识Qt Creator界面 2.1 main.cpp 代码解释 2.2 mywidget.h 代码解释 2.3 mywidget.cpp 代码解释 2.4 form file —— Forms里的mywidget.ui 2.5 .pro文件 2.6 编译生成的中间文件 Qt Creator是一个跨平台集成开发环境(IDE),专门用…

Vue3使用markdown编辑器之Bytemd

官网地址:https://bytemd.js.org/playground GitHub地址:https://github.com/bytedance/bytemd ByteMD 是字节跳动出品的富文本编辑器,功能强大,可以免费使用,而且支持很多掘金内置的主题,写作体验很棒。 …

Android约束布局的概念与属性(1)

目录 1.相对定位约束2.居中和偏移约束 约束布局(ConstraintLayout)是当前Android Studio默认的布局方式,也是最灵活的一种布局方式。约束布局推荐使用所见即所得的模式进行布局,约束布局的大部分布局可以通…

CentOS7下安装Doris

Doris简介 Apache Doris 是一款基于 MPP 架构的高性能、实时的分析型数据库,以高效、简单、统一的特点被人们所熟知,仅需亚秒级响应时间即可返回海量数据下的查询结果,不仅可以支持高并发的点查询场景,也能支持高吞吐的复杂分析场…

SpringBoot升级引发一个循环依赖支持问题

最近有个重要的项目要求使用带自定义表单的工作流。要求灵活配置流程。选用了较稳定的Flowable6.72版本。但面临着一个问题。教材上,Flowable6.7.2要求匹配的SpringBoot版本是2.6.2.需要对项目的Boot版本从2.3releae升到2.6.2,其他还好。不存在有类编译问题或类找不到问题。就是…

互联网银行每日2TB数据量,Apache SeaTunnel集成应用轻松搞定!

在我国,数字化的趋势驱动互联网银行发展走上快车道,近年来互联网银行发展迅速,积极拓展线上业务,并利用大数据技术加强风险控制,积极进行数字化转型。当新兴互联网银行乘着数字化改革的风潮搭档数据集成平台Apache Sea…

Android 15 适配之16K Page Size :为什么它会是最坑的一个适配点

首先什么是 Page Size ?一般意义上,页面(Page)指的就是 Linux 虚拟内存管理中使用的最小数据单位,页面大小(Page Size)就是虚拟地址空间中的页面大小, Linux 中进程的虚拟地址空间是由固定大小的页面组成。 Page Size 对于虚拟内…

如何把harmonos项目修改为openharmony项目

一开始分不清harmonyos和openharmony,在harmonyos直接下载的开发软件,后面发现不对劲,打脑阔 首先你要安装对应版本的开发软件,鸿蒙开发是由harmonyos和openharmony官网两个的,找到对应的地方下载对应版本的开发软件&…

rocketmq实现限流

目录 问题背景 技术方向 方案确认 消息队列(√) 分布式锁() 方案实现 监控方向 业务方向 问题背景 公司邮件服务token有 分钟内超200封的熔断机制,当前token被熔断后,系统发邮件操作会被忽略&…

关于微信支付-商户平台:查询订单提示“查询失败:操作失败,请稍候重试”的分析

目录 引子 分析 应对 小结 引子 在开发和实施微信 JSAPI 支付的应用后,我们遇到了一些问题,订单的状态更新不正常,当然我们首先需要从自身寻找原因和完善解决问题的办法和方案。在支付的过程中,客户会给我们一些反馈&#xf…

K8S篇之Ingress详解以及用法说明

一、Ingress简介 Ingress 是 Kubernetes 中用于管理和配置从集群外部访问集群内部服务的资源对象。它通过定义路由规则来控制外部流量的访问方式,支持基于 HTTP 和 HTTPS 的高级路由功能和安全性配置。 Ingress是一种HTTP方式的路由转发机制,为K8S服务配…