| « Поставить закладку » « Сделать стартовой » | |||
|
|||
|
Статьи:: Базы данных :: ADO .NET :: Параметризованные запросы ADO.NET - средство защиты от «SQL Injection» атак
Параметризованные запросы ADO.NET - средство защиты от «SQL Injection» атак
«SQL Injection» атаки возможны в приложениях, не проверяющих полученные от пользователя данные. Уязвимое приложение использует полученные данные для построения динамического SQL запроса и последующего (его) выполнения. Подобный тип уязвимостей характерен как для веб-приложений (ASP.NET, ASP, PHP и так далее), так и для обычных приложений. Однако, для веб-приложений они наиболее критичны, из-за широкой аудитории пользователей. Возможные последствия атаки:
В этой статье мы рассмотрим борьбу с «SQL Injection» атаками на примере приложения ASP.NET. Приведенный ниже метод, однако, подходит и для приложений Windows Forms. Примеры «SQL Injection» атакРассмотрим, например, форму авторизации на некотором сайте. Фрагмент кода из ASPX файла:
Затем в code behind файле:
Приведенный выше код выполняет динамический SQL запрос к таблице со списком пользователей и их паролями. Если результатом запроса является 1, значит, пользователь с заданным именем и паролем существует. Представим теперь, что в качестве имени пользователя введена строка:
И тогда наш код сформирует следующий SQL запрос:
Одинарная кавычка в имени пользователя закрывает ранее открытую одинарную кавычку, а строка «--» превращает в комментарий все, что следует дальше. Соответственно значение пароля не участвует в проверке и если пользователь admin существует, то результатом запроса будет 1 и успешный вход в защищенную часть сайта! Итак, злоумышленник смог успешно пройти процедуру авторизации на нашем сайте, зная только имя пользователя. Как еще он может использовать найденную уязвимость? Он может ввести в качестве имени пользователя следующую строку:
Результатом выполнения такого запроса может стать удаление таблицы Users. Успешность этого шага зависит от привилегий пользователя БД от имени которого выполняется запрос. Следует всегда стараться использовать учетную запись с минимально необходимым набором привилегий и никогда учетную запись администратора БД. Защита от «SQL Injection» атакОдним из методов защиты является отказ от использования динамических SQL запросов. Параметризованные запросы и хранимые процедуры защитят ваше приложение от подобных атак. Например, вышеприведенный код на С# можно переписать следующим образом:
Используя параметризованный запрос, мы защищаем себя от типичных сценариев атак. Еще лучшим методом защиты БД является использование хранимых процедур. Защита базы данных в этом случае обеспечивается за счет того, что пользователю даются только права на выполнение хранимых процедур. Ваш код затем обращается к хранимым процедурам БД от имени подобной непривилегированной учетной записи. Хранимые процедуры в свою очередь выполняют операции INSERT/UPDATE/DELETE. Вызов хранимой процедуры для авторизации пользователя может выглядеть, например, так:
Также имеет смысл отключать подробные сообщения об ошибках выводимые ASP.NET, чтобы исключить использование этой информации злоумышленником. Именно из текста сообщения об ошибке злоумышленник может узнать о структуре БД. В случае ошибки в веб-приложении пользователю должно выдаваться минимум информации. Ни в коем случае не следует выводить полное сообщение об ошибке. В общем случае достаточно информировать посетителя о ее наличии, а полный текст сообщения об ошибке занести в журнал событий и/или отправить уведомление администратору сайта по электронной почте. ЗаключениеПриведенные выше методы являются скорее необходимыми, чем достаточными для поддержания необходимого уровня защищенности веб-приложения, и должны использоваться как еще один, но не единственный, рубеж обороны. Автор: Василий Петрухин, статья была взята с сайта relib.com Рубрика: ADO .NET
HTML 5: пять вещей вызывающих особый интер....
HTML 5 — это грядущее обновление гипертекстового языка разметки, основного способа создания контента для размещения его во всемирной паутине. Разработка HTML остановилась в 1999 году, на версии HTML 4.01 и с тех пор web-содержимое изменилось так, что текущие спецификации HTML перестали соответствовать сегодняшним требованиям. HTML 5 нацелен на то, чтобы увеличить функциональную совместимость HTML и соответствовать растущим требованиям разнообразного и смешанного web-контента. HTML 5 так же нацелен на устранение недостатков четвертой версии. В этой статье мы взглянем на 5 новых интересных вещей в HTML 5.
Подробнее... |
Рубрика: Html
| Добавлено: 22.12.2008
asp.net: ListView с разных сторон.
Элемент управления ListView был представлен в .Net Framework 3.5 как замена устаревшему GridView. Новый элемент имеет более расширенный функционал, чем его предшественник, но в тоже время лишен некоторых внутренних механизмов, что впрочем целиком следствие из расширенной универсальности ListView. Среди отличий ListView и GridView можно назвать и гибкую настройку разметки, что позволяет выводить данные не только в табличном виде, но и вообще в любом каком пожелает программист. Благодаря шаблонам ItemTemplate, EditItemTemplate, InsertItemTeplate можно настроить внешний вид при любом из состояний ListView: редактировании или выборе элемента.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Создание кросс-таб отчета в Stimulsoft Rep....
Компания Стимулсофт предоставляет для разработчиков мощный набор инструментов для создания отчетов для Microsoft Visual Studio .Net 2005 и 2008; эти инструменты доступны как для Windows Forms, так и для Web Forms. Это генератор отчетов Stimulsoft Reports.Net. Генератор отчетов Stimulsoft Reports.Net имеет ряд особенностей: простая работа с дизайнером отчетов, полная поддержка экспорта в PDF, Word, Excel и многие другие форматы. Crystal Report и Microsoft Reporting Service – очень хорошие программные продукты для повседневной работы, но, если Вам необходимо создать отчеты с поддержкой кросс-табов, drill down, Ajax, штрих-кодов и возможностью подключения одновременно более одного источника данных, то Stimulsoft Reports.Net поможет Вам сэкономить массу времени. Также, данный генератор отчетов позволяет пользователям создавать свои собственные отчеты любой сложности. И все эти особенности делают Stimulsoft Reports.Net хорошим выбором в сфере программных продуктов для Business Intelligence.
Подробнее... |
Рубрика: .NET компоненты
| Добавлено: 22.12.2008
Остальные статьи: |
Цитата дня (все,добавить):
|
Realcoding.NET
© 2003-2008 |
Контакты |
Реклама на сайте
|