mysql数据库udf提权
发布于 2021-05-13 21:25 ,所属分类:数据库和大数据技术学习资料
mysql数据库udf提权
UDF介绍
UDF提权复现
udf提权的前提条件
0x01 判断mysql版本
0x02 查看mysql是否有写入文件的权限
0x03 使用MDUT 工具写入udf.dll
0x04 使用msf进行udf提权
最近面试经常被问到udf提权,奈何每次都回答不上来,于是有了下面的学习过程。
UDF介绍
UDF (user defined function),即用户自定义函数。通过添加新函数,对MySQL数据库的功能进行扩充,就像使用本地MySQL函数如 database() 或 version() 一样。
UDF提权复现
udf提权的前提条件
① 知道数据库的用户和密码
② mysql可以远程登录
③mysql有写入文件的权限,即secure_file_priv的值为空。
0x01 判断mysql版本
在mysql>5.1版本,udf.dll应放置在mysql安装目录的lib\plugin下
mysql<5.1版本udf.dll应放置在C:\windows或者C:\windows\system32目录
selectversion();
data:image/s3,"s3://crabby-images/60d04/60d044bd55dda0a222553cf941450577df7d408e" alt=""
我的mysql版本是5.5.53,udf.dll 应该放在mysql/lib/plugin 目录下。由于mysql安装目录下lib\plugin是不存在的,所以手工创建好。
data:image/s3,"s3://crabby-images/1f826/1f826963d0f9fde7f694316b47287c10dad7e07b" alt=""
0x02 查看mysql是否有写入文件的权限
showvariableslike'%secure%'
data:image/s3,"s3://crabby-images/e0b6a/e0b6a959fa438e0773e5a8a64736d7d56fa6e90b" alt=""
如果secure_file_priv 为空则允许写入文件。
如果具备这两个条件和可以远程登录,我们就可以用MDUT 工具写入udf.dll了 。
0x03 使用MDUT 工具写入udf.dll
下载地址:https://github.com/SafeGroceryStore/MDUT
data:image/s3,"s3://crabby-images/49fee/49fee781e5dbc7c35dbead20e38dcbf858bd353c" alt=""
data:image/s3,"s3://crabby-images/b982d/b982d7c9339ec42b336f6e27cb6649429703b701" alt=""
data:image/s3,"s3://crabby-images/870ed/870ed21fd5227042e657619a1e636484a2b1ecd6" alt=""
测试一下
data:image/s3,"s3://crabby-images/92e03/92e037743263a3cd61ab9643a3eb3f3a65ba90a4" alt=""
data:image/s3,"s3://crabby-images/9225d/9225daccade51a0b6da08ddf26fb0ffb3cb5ff84" alt=""
0x04 使用msf进行udf提权
msf6exploit(multi/mysql/mysql_udf_payload)>
配置password 、rhosts 、 username
data:image/s3,"s3://crabby-images/9b6cc/9b6ccb955f718028d3a7ed0d68f1bb3e7ce29418" alt=""
成功写入udf.dll
data:image/s3,"s3://crabby-images/ea7cd/ea7cd6d3c55754a350bea87af6598f76cbf98603" alt=""
data:image/s3,"s3://crabby-images/412bd/412bd6ee9a5a2dd69cce5a7a4a1b30cf8f190093" alt=""
自定义函数sys_eval()和sys_exec() 两个执行命令的函数可以直接调用。
sys_exec()函数无回显
执行成功返回0 执行失败返回1
data:image/s3,"s3://crabby-images/12616/12616ac06cd74250e8d92bbcf25278703a38691d" alt=""
data:image/s3,"s3://crabby-images/a3c5f/a3c5f2aadb6f9bf38e67cae45b8411e258394264" alt=""
sys_eval()函数有回显
data:image/s3,"s3://crabby-images/f6d1b/f6d1bc80994784795928cc10d568fe9eeda2257e" alt=""
相关资源