基于W1R3S的渗透测试

news2025/1/11 2:45:24

您被雇来对W1R3S做渗透测试,他们要求您获得root权限并找到标志(位于/root目录中)。
目标:得到root权限&找到flag.txt

目录

1、信息收集

(1)定位靶机IP

(2)端口扫描

(3)脚本扫描

(4)全面扫描

2、FTP渗透

3、Web渗透

4、john爆破

5、ssh远程登录

6、sudo提权


下载好靶机w1r3s,网络改为NAT模式(确保在同一网段)

1、信息收集

(1)定位靶机IP

先不要开靶机,我们先用nmap扫一下整个子网存活的设备

nmap -sn 192.168.47.0/24

默认情况下nmap会同时进行活跃状态和端口状态扫描,使用参数 -sn只进行活跃状态扫描

发现只有四个活跃设备

现在我们打开靶机

再次使用nmap进行上述扫描

nmap -sn 192.168.47.0/24

 发现多出了一台设备,至此我们成功定位到了靶机的IP为192.168.88.131

(2)端口扫描

我们知道端口数量有65536个,但实际上nmap默认只会扫描65536中最常用的1000个端口,即如果我们不加任何参数,nmap扫描的是1000个端口,而不是65536个。

使用最小速率10000来扫描靶机ip开放端口,默认是tcp扫描

nmap --min-rate 10000 -p- 192.168.47.154

nmap扫描端口的命令是“nmap -p <port ranges> <target>”,其中<port ranges>表示要扫描的端口范围,可以使用单个端口号、多个端口号之间用逗号隔开,或者使用“-”表示连续的端口范围;<target>表示要扫描的目标地址。

对65536个端口扫描:追加参数 -p "*"

nmap -p "*" 192.168.88.131

不过我们一般不会这样用

我们可以扫描使用频率最高的一些端口,比如对最常用的20个端口扫描

nmap --top-ports 20 192.168.88.131

从这三次的扫描结果我们可以看到有四个端口开放,分别是:21、22、80、3306

21端口可能存在未授权登录,可以尝试匿名登录;22端口可能存在ssh爆破;80端口的web服务可能存在web漏洞可以利用;3306端口是MySQL的默认端口,若Mysql的身份认证存在漏洞,攻击者可以不必提供正确的身份证书便可访问Mysql数据库。

(3)脚本扫描

我们使用nmap自带的web漏扫脚本对这些开放的端口进行扫描

nmap --script=vuln -p21,22,80,3306 192.168.88.131

发现存在低速率DOS(拒绝服务)攻击

不过该漏洞用处不大,这里忽略

(4)全面扫描

我们追加参数 -A 进行全面扫描(-p和前面一样用来指定端口,这里表示全端口扫描)

nmap -p- -A 192.168.88.131

 可以看到匿名登录是允许的,接下来我们直接进行FTP渗透

2、FTP渗透

ftp 192.168.88.131

用户名为 anonymous ,密码为空

 登陆成功

ls查看当前目录,发现有三个目录,依次进入查看

由于此处远程下载的目标文件均为txt文件, 所以在下载传输的过程中文件是不会损坏的, 若下载的文件为可执行文件或其他二进制文件, 那么需要先执行binary命令再使用mget命令下载文件。

记得要使用 cd .. 先返回到上一级目录,再切换进入其他目录,直接切换是不行的

同样将txt文件下载到本地

 

查看txt文件内容

01.txt, 其文本内容意思是:"为W1R3S准备的新的FTP服务器", 属于无效信息

02.txt, 内容是两段加密后的字符串,很明显第二个是base64,而第一个则是MD5加密

03.txt, 是一段艺术字体,目前来看也没什么用

对02.txt的内容解密

This is not a password(这不是密码)


 It is easy, but not that easy..(这很容易,但没那么容易..)

基本上都是无用信息

查看employee-names.txt文件, 是一份员工列表

查看worktodo.txt, 文件内容是一段颠倒的字符串

 进行一些倒置反向处理

 大概意思是"我不认为这是拿到root权限的一种方式, 我们有很多工作要做, 停止在这里玩耍..."

暗示我们得换个方向

3、Web渗透

直接访问目标ip地址,查看靶机80端口的web服务,发现是个apache的主页

使用dirsearch对目标主机80端口的web服务进行目录爆破

dirsearch -u 192.168.88.131

爆出两个可疑目录/administrator和/wordpress( wordpress这个框架存在很多漏洞) 

也可使用dirb命令实现目录爆破

dirb http://192.168.88.131

 结果同上

我们对/administrator目录进行访问

尝试安装,但在添加完信息之后发现没有Administrator创建权限

 

而/wordpress目录则无法访问 

从网站的标题可以看出是该网站的cms为Cuppa,

也可以使用whatweb命令查询

使用searchsploit命令查询Cuppa cms是否存在漏洞

searchsploit cuppa cms

发现存在一处漏洞, 漏洞详情保存在25971.txt中, 将它导出来

searchsploit cuppa cms -m 25971.txt

 查看漏洞详情得知, 该cms可通过文件包含漏洞读取任意文件

文件中描述说,/alerts/alertConfigField.php文件urlConfig参数存在LFI(PHP本地文件包含漏洞),可以利用特殊的url,查看本地文件

并且给出了几个payload

使用第二个payload尝试,target就是靶机ip,cuppa是显示cuppa信息的访问页面,即administrator

http://192.168.88.131/administrator/alerts/alertConfigField.php?urlConfig=../../../../../../../../../etc/passwd

没有回显

由于url里是get请求,我们换用post请求再试试

使用curl命令提交Post请求:

curl -X POST -d urlConfig=../../../../../../../../../etc/passwd http://192.168.88.131/administrator/alerts/alertConfigField.php

成功得到目标主机的passwd文件内容

用同样的方法尝试读取shadow文件,该文件是用来存放用户名密码的

curl -X POST -d urlConfig=../../../../../../../../../etc/shadow http://192.168.88.131/administrator/alerts/alertConfigField.php

发现两处很明显的用户信息
分别对应着www-data用户:加密密码,w1r3s用户:加密密码 

4、john爆破

创建一个新文本将shadow内两处用户信息保存进去

使用john命令进行破解

破解成功,得到:

用户 www-data  密码 www-data
用户 w1r3s  密码 computer 

5、ssh远程登录

因为开放了22端口,所以可利用得到的客户端用户名及靶机ip来进行ssh连接

命令格式: ssh 客户端用户名@服务器ip地址

ssh w1r3s@192.168.88.131

远程登录成功 

whoami  查看一下当前用户是谁
uname -a   查看系统状态
sudo -l   查看当前用户权限

可以看到当前用户具有所有权限

6、sudo提权

因为w1r3s这个用户具有全权限,这里可以直接提权至root用户

sudo su  (sudo可以理解为以管理员身份运行,即以root用户执行命令,su是切换用户)

提权成功

切换到root根目录,直接找到flag

 至此,已经完全拿下整台靶机

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

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

相关文章

【HTMLCSSJS】写实验发现的一些注意点

&#x1f38a;专栏【 前端易错合集】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【如愿】 大一同学小吉&#xff0c;欢迎并且感谢大家指出我的问题&#x1f970; 目录 &#x1f6a5;innerHtml和innerText的区别 &#x1f3f…

28-Servlet API

1.HttpServlet 我们写 Servlet 代码的时候&#xff0c;⾸先第⼀步就是先创建类&#xff0c;继承⾃ HttpServlet&#xff0c;并重写其中的某些⽅法。 1.1.核心方法 实际开发的时候主要重写 doXXX ⽅法&#xff0c;很少会重写 init / destory / service。 这些⽅法的调⽤时机&…

c++基础-运算符

目录 1关系运算符 2运算符优先级 3关系表达式的书写 代码实例&#xff1a; 下面是面试中可能遇到的问题&#xff1a; 1关系运算符 C中有6个关系运算符&#xff0c;用于比较两个值的大小关系&#xff0c;它们分别是&#xff1a; 运算符描述等于!不等于<小于>大于<…

2 异或位运算大厂必刷题

文章目录 如何不用额外变量交换两个数一个数组中有一种数出现了奇数次&#xff0c;其他数都出现了偶数次&#xff0c;怎么找到并打印这种数怎么把一个int类型的数&#xff0c;提取出最右侧的1来怎么把一个int类型的数,获取位数为1的数量一个数组中有两种数出现了奇数次&#xf…

开发问题记录20230502

4 Docker普通用户无权限 普通用户执行docker命令提示信息&#xff1a; docker images docker ps -adocker: Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Post “http://%2Fvar%2Frun%2Fdocker.sock/v1.24/c…

Java 的简要介绍及开发环境的搭建(超级详细)

图片来源于互联网 目录 | CONTENT Java 简介 一、什么是 Java 二、认识 Java 版本 三、选择哪个版本比较好 搭建 Java 开发环境 一、下载 Java 软件开发工具包 JDK 二、配置环境变量 自动配置 手动配置 三、下载合适的 IDE IntelliJ IDEA Visual Studio Code Eclip…

Flutter 组件使用:使用 Stack 替代 GlobalKey 的定位 tip-widget 实现

场景 有时候需要在指定位置进行 tip-widget 的弹出与展示&#xff0c;常见的方式是通过给指定位置上的指定 widget 添加 GlobalKey 来实现&#xff1b; 但是&#xff0c;使用这种方式的话&#xff0c;【一】大多数时候都需要进行全局定位转换&#xff08;localToGlobal&#…

c++ 11标准模板(STL) std::vector (三)

定义于头文件 <vector> template< class T, class Allocator std::allocator<T> > class vector;(1)namespace pmr { template <class T> using vector std::vector<T, std::pmr::polymorphic_allocator<T>>; }(2)(C17…

Winform从入门到精通(36)——ColorDialog(史上最全)

文章目录 前言一、属性1、AllowFullOpen2、AnyColor3、Color4、FullOpen5、ShowHelp6、SolidColorOnly7、Tag二、事件1、HelpRequest前言 当我们需要设置某个控件的颜色时,并且需要弹出一个可以选择颜色的对话框时,这时候就需要使用ColorDialog 一、属性 1、AllowFullOpen…

LoadRunner 安装指南:详解安装步骤和常见问题解决方法

目录&#xff1a;导读 引言 LoadRunner安装 LoadRunner的安装 结语 引言 作为一款领先的性能测试工具&#xff0c;LoadRunner 被广泛应用于各种企业级应用程序和系统的性能测试中。然而&#xff0c;对于初学者来说&#xff0c;正确安装 LoadRunner 并不是一件容易的事情。…

Spring 填充属性和初始化流程源码剖析及扩展实现

前言 在上一篇博文 讲解 Spring 实例化的不同方式及相关生命周期源码剖析 介绍了 Spring 实例化的不同方式&#xff0c;本文主要围绕实例化过后对象的填充属性和初始化过程进行详细流程剖析 回顾前言知识&#xff0c;doCreateBean->createBeanInstance&#xff0c;通过 S…

沁恒 CH32V208(二): CH32V208的储存结构, 启动模式和时钟

目录 沁恒 CH32V208(一): CH32V208WBU6 评估板上手报告和Win10环境配置沁恒 CH32V208(二): CH32V208的储存结构, 启动模式和时钟 CH32V 存储容量命名方式 在介绍下面的内容前, 先看一下CH32V系列和存储相关的命名格式, 以CH32V203为例, 前面的CH32V203代表一个系列, 后面的字…

剑指offer(C++)-JZ47:礼物的最大价值(算法-动态规划)

作者&#xff1a;翟天保Steven 版权声明&#xff1a;著作权归作者所有&#xff0c;商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处 题目描述&#xff1a; 在一个m\times nmn的棋盘的每一格都放有一个礼物&#xff0c;每个礼物都有一定的价值&#xff08;价值大于…

使用CometD技术实现web系统中的主动推送

CometD技术通过Http长轮询(或websocket长链接)方式在服务器与客户端之间构建了一条交互的链路。它们都遵守Bayeux协议,交换的消息是Bayeux message,消息格式是JSON。 1、需求说明 当用户登录后,后台根据用户订阅把最新的信息反推给web客户端,展示在页面上。CometD服务器…

菜地管理系统【控制台+MySQL】(Java课设)

系统类型 控制台类型Mysql数据库存储数据 使用范围 适合作为Java课设&#xff01;&#xff01;&#xff01; 部署环境 jdk1.8Mysql8.0Idea或eclipsejdbc 运行效果 本系统源码地址&#xff1a;https://download.csdn.net/download/qq_50954361/87737285 更多系统资源库地…

计算机组成原理9控制单元的结构

9.1操作命令的分析 取值周期间址周期执行周期中断周期 取指周期数据流 PC存放下条指令的地址给MAR访问存储器相应单元&#xff0c;将数据取出来送给MDR寄存器&#xff0c;MDR取出来的内容送给IR指令寄存器&#xff0c;然后对指令进行译码&#xff0c;把指令的操作码部分取出…

医学图像的深度学习的完整代码示例:使用Pytorch对MRI脑扫描的图像进行分割

图像分割是医学图像分析中最重要的任务之一&#xff0c;在许多临床应用中往往是第一步也是最关键的一步。在脑MRI分析中&#xff0c;图像分割通常用于测量和可视化解剖结构&#xff0c;分析大脑变化&#xff0c;描绘病理区域以及手术计划和图像引导干预&#xff0c;分割是大多数…

MySQL解析器和优化器,你了解它们吗?

解析器都做哪些事情 其主要功能是将输入的SQL语句分解为语法单元&#xff0c;然后将这些语法单元转换为内部表示的数据结构&#xff0c;最终生成一个可执行的查询计划。解析器是MySQL中的一个重要组成部分&#xff0c;它直接影响查询的性能和正确性。 词法分析&#xff1a; …

【win11的CARSIM2020安装教程最全,包括下载地址,关闭防火墙】

carsim2020.0软件下载地址参考&#xff1a;https://www.cnblogs.com/bbman/p/15148890.html 百度网盘提取后&#xff0c;先关闭防护墙。 如何永久关闭windows defender杀毒软件。 第一种方式 安装某一杀毒软件&#xff0c;比如某管家、某60&#xff0c;杀毒软件会覆盖Defender…

PC或服务器装双系统

1. 准备工作 1.1U盘启动盘的制作 ①准备一个 4G 以上的 U 盘&#xff0c;备份好U盘资料&#xff0c;后面会对 U 盘进行格式化。 ②去CentOS官网下载你想要安装的 ISO 格式镜像文件&#xff0c;现在通常是CentOS6、7或者8。如果你英文不太好&#xff0c;可以选择使用edge浏览…