千家信息网

Mysql注入中outfile、dumpfile、load_file函数的示例分析

发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,这篇文章将为大家详细讲解有关Mysql注入中outfile、dumpfile、load_file函数的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在利用s
千家信息网最后更新 2025年01月22日Mysql注入中outfile、dumpfile、load_file函数的示例分析

这篇文章将为大家详细讲解有关Mysql注入中outfile、dumpfile、load_file函数的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

在利用sql注入漏洞后期,最常用的就是通过mysql的file系列函数来进行读取敏感文件或者写入webshell,其中比较常用的函数有以下三个

  • into dumpfile()

  • into outfile()

  • load_file()

我们本次的测试数据如下

读写文件函数调用的限制

因为涉及到在服务器上写入文件,所以上述函数能否成功执行受到参数 secure_file_priv 的影响。官方文档中的描述如下

翻译一下就是

  • 其中当参数 secure_file_priv 为空时,对导入导出无限制

  • 当值为一个指定的目录时,只能向指定的目录导入导出

  • 当值被设置为NULL时,禁止导入导出功能

这个值可以通过命令 select @@secure_file_priv 查询。由于这个参数不能动态更改,只能在mysql的配置文件中进行修改,然后重启生效。

dumpfile与outfile的区别

导出数据库场景下的差异

select …… into outfile

我们先来看一下mysql官方文档里对于这两个函数的解释

其中有两个值得注意的坑点

outfile函数可以导出多行,而dumpfile只能导出一行数据
outfile函数在将数据写到文件里时有特殊的格式转换,而dumpfile则保持原数据格式

我们接下来通过导出测试看看这里面的细节

首先通过命令 select * from test into outfile '/tmp/test.txt' 来使用outfile导出

可以看到文件 /tmp/test.txt 文件中保存了所有的数据并且在一行数据的末尾自动换行

通过查看官方文档,可以看出使用如下参数可以进行格式调整

其中 FIELDS ESCAPED BY 可以用来对指定的字符进行转义, FIELDS [OPTIONALLY] ENCLOSED BY 用来对字段值进行包裹, FIELDS TERMINATED BY 用来对字段值之间进行分割

例如使用如下命令 select * from test into outfile '/tmp/test.txt FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY ' " 'LINES TERMINATED BY '\n'

得到的导出文件如下

select …… into dumpfile

而接着使用命令 select * from test into dumpfile '/tmp/test.txt' 使用dumpfile进行导出

可以看到此命令在执行的时候提示输出超过一行

查看文件内容

可以看见通过dumpfile导出的数据行数据之间并未进行换行且只导出了部分数据

写入webshell或者udf下的差异

select …… into outfile

我们使用命令 select 'a\naa\raaaa' into outfile '/tmp/test.txt' 来看一下在常用的写文件场景下的结果

可以看到outfile对导出内容中的\n等特殊字符进行了转义,并且在文件内容的末尾增加了一个新行

我们接着使用命令 select 'a\naa\raaaa' into dumpfile '/tmp/test.txt' 来看一下

可以看到dumpfile对文件内容是原意写入,未做任何转移和增加。这也就是为什么 我们在平常的UDF提权中使用dumpfile进行dll文件 写入的原因

还有一个需要关注的点就是:outfile后面不能接0x开头或者char转换以后的路径,只能是单引号路径。这个问题在php注入中更加麻烦,因为会自动将单引号转义成\',那么基本就GG了,但是load_file,后面的路径可以是单引号、0x、char转换的字符,但是路径中的斜杠是/而不是\

关于"Mysql注入中outfile、dumpfile、load_file函数的示例分析"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

文件 数据 函数 命令 内容 参数 路径 一行 字符 官方 就是 常用 引号 文档 格式 篇文章 转义 示例 分析 特殊 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 国外高校学生网络安全知识培养 如何用命令修改数据库的储存引擎 齐鲁证券网络技术部李维 基于对象的数据库是怎么查询的 美国网络安全市场规模增速 数据库二维表 甲骨文自制数据库 网络安全好还是网络开发应用好 攀枝花软件开发厂家价格 服务器里怎么建造刷怪塔 数据库链接如何发送 赣榆区淘乐网络技术服务工作室 关于购买网络安全设备的申请 一对多怎么数据库查询 杭州市捕网络技术有限公司 服务器高负载 上海市徐汇区网络安全检查 怎么查看数据库字符 数据库数据复制连接怎么编程 绱佳网络技术有限公司 软件开发英语面试自我介绍 戴尔720服务器选择启动项 软件开发1人月等于多少人天 软件开发的项目答辩PPT 数据库代码怎样插入数据 其他专业学习网络安全从哪学起 剑魂之刃是什么软件开发的 方舟服务器总管理 网络安全教育讲座报道 四川新一代网络技术分类产品介绍
0