Протокол HTTPS и уязвимости сайта: безопасные связи
Как сообщает Google, количество взломов сайтов в интернете выросло на 32% в 2016 году по сравнению с предыдущим годом, и данная тенденция продолжит свое развитие. Возможно, это может быть удивительным, учитывая усиление уровня безопасности сайтов как в количестве, так и в качестве. Тем не менее, статистические данные не дают повода расставаться с осторожностью, особенно когда дело касается защиты сайтов от хакеров. В этой статье мы рассмотрим технические аспекты безопасного протокола соединения HTTPS, стандарты сертификации безопасности сайтов и различные виды уязвимости порталов.
Атаки на веб-ресурсы обычно нацелены на сайты, такие как банки, мобильные операторы, компании, известные медиапорталы и правительственные учреждения. Они обозначают эти сайты, потому что они могут принести огромную прибыль, а также дать доступ к записи ценной информации. Даже те сайты, которые привлекают небольшое количество посетителей в день, могут также потерпеть поражение от киберпреступников.
Собственникам небольших сайтов не следует отчаиваться, думая, что они не будут стать жертвой хакеров. Небольшие сайты часто использовались в качестве тренировочной площадки для атаки на крупные порталы. Или они могут стать жертвой массовой атаки, когда сотни или тысячи ресурсов выбираются по определенному принципу. Считается, что каждый третий сайт может быть подвергнут атакам со стороны злоумышленников, которые постоянно исследуют возможные уязвимости, обнаруженные на сайтах. Поэтому главным приоритетом владельца сайта является максимально возможное обеспечение безопасности сайта от возможных угроз, чтобы сохранить важные данные и свои деньги.
Зачастую сайты страдают от уязвимостей, через которые осуществляются большинство атак. Эти "уязвимости" – изначальные дефекты в коде или программном обеспечении сайта, которые могут быть использованными нарушителем для нарушения работы системы. Происхождение уязвимостей может быть связано с ошибками в проектировании сайта или нерадивым поведением пользователей, которые устанавливают ненадежные пароли.
Например, системы аутентификации и управления сессиями, небезопасные прямые ссылки на объекты и отсутствие контроля доступа к функциональному уровню – наиболее распространенные уязвимости. Более тщательная проверка и настройка конфигурации сайта могут также предотвратить возможные атаки. Некоторые уязвимости могут приводить к утечке ценной информации, атакующие могут добраться до чувствительных данных, таких как пароли или личные данные пользователей.
Другие типы уязвимостей могут включать использование устаревших компонентов, "невалидированные" перенаправления или "кликджекинг" - техники, используемые для незаметного перенаправления пользователей на другие сайты или выполнения нежелательных действий без их ведома. По сути, уязвимости сайта подобны открытому ларчику, который может быть легко взломан и обокраден.
Протокол передачи данных HTTP не обеспечивает достаточной защиты данных и оставляет их подверженными угрозам хакеров. В целях гарантированной безопасности информации был разработан протокол HTTPS, использующий криптографическую систему SSL/TLS для шифрования всех передаваемых данных и защиты соединения через незащищенный канал.
Соединение по протоколу HTTPS устанавливается путем генерации общего секретного ключа между компьютером пользователя и сервером, после чего данные шифруются с использованием этого ключа. Новый ключ создается каждый раз при установке соединения, поэтому его перехват или подбор практически невозможен, так как он содержит более 100 знаков. Также для обеспечения безопасности соединения используется цифровой сертификат для проверки подлинности сервера. Браузер перед началом обмена данными автоматически проверяет подлинность сертификата и только после его подтверждения начинает передачу информации.
Перевод сайта на протокол HTTPS – процесс, который на первый взгляд может показаться сложным, но на самом деле состоит всего из нескольких простых шагов.
Шаг 1. Получение и настройка сертификата.
Для получения сертификата можно обратиться в центры сертификации и заплатить за эту услугу или воспользоваться бесплатными вариантами. Небольшие фирмы могут использовать бесплатные сертификаты, но крупные компании чаще предпочитают платные сертификаты с расширенной аутентификацией и другими удобствами. Бесплатные сертификаты могут увеличивать время передачи данных, а также не подходят для сайтов, где принимаются онлайн-платежи. Независимо от того, платный ли сертификат, его необходимо настроить и выполнить переадресацию всех http-запросов на https.
Шаг 2. Работа с внутренними ссылками.
После установки сертификата необходимо заменить ссылки внутри сайта с полных на относительные с помощью скриптов. Это поможет избежать ситуации, когда после перехода на протокол HTTPS происходит загрузка смешанного контента, что не обеспечивает полноценной защиты и может привести к неработоспособности сайта.
Шаг 3. Переадресация.
После установки сертификата сайт станет доступен по двум адресам, поэтому нужно настроить прямой редирект «301» с http на https. Это можно сделать на сервере или в файле .htaccess. После выполнения этого шага все http-запросы будут автоматически переадресовываться на сайт с протоколом HTTPS.
Шаг 4. Внесение изменений в файл robots.txt.
Чтобы поисковые роботы могли обнаружить сайт с измененным протоколом, нужно указать этот протокол в файле robots.txt.
Шаг 5. Включение HTTPS Strict-Transport-Security.
Этот процесс индивидуален для каждого сервера, поэтому для облегчения задачи следует обратиться к специалистам, которые разрабатывали сайт. Наконец, необходимо включить Secure Cookies для надежной защиты информации на сайте.
Вот и все, теперь ваш сайт переведен на протокол HTTPS!
Когда дело доходит до выбора сертификата для защиты сайта, вам придется сделать выбор между двумя типами сертификатов. Если вы владеете небольшим офлайн-бизнесом или личным блогом и хотите просто донести информацию о своей компании до потенциальных клиентов, то вам подойдет Domain Validation SSL. Данный вид проверки не позволяет использовать сертификат для защиты субдоменов или для финансовых операций через сайт. Однако, такие сертификаты выдаются быстро, и после подтверждения владения доменом, вы можете начать их использование сразу же. Вы можете подтвердить владение доменом несколькими способами, включая отправку подтверждающего e-mail, запись в DNS или использование хэш-файла. Такой сертификат оценен относительно низко по цене, примерно 610 рублей в год.
Если же вы собираетесь вести финансовые онлайн-операции через свой сайт, вам необходимо установить сертификат Business Validation. Данный вид сертификата более надежный, так как помимо подтверждения владения доменом, он связывает компанию с сайтом. Для прохождения проверки подтверждения, вы должны отправить пакет документов в центр верификации и принять звонок на корпоративный номер. Все сертификаты Business Validation разделены на следующие виды:
- Extended Validation SSL – используется банками, платежными системами, крупными интернет-магазинами и другими организациями, работающими с большими объемами денежных средств.
- Wildcard SSL – защищает сам сайт и его поддомены. Используется, когда на сайте предполагается несколько поддоменов с разной региональной привязкой.
- SAN SSL – поддерживает внешние и внутренние альтернативные доменные имена.
- CodeSigning SSL – подтверждает безопасность кодов и программных продуктов с сайта, идеальный выбор для разработчиков приложений.
Независимо от выбранного сертификата, в первую очередь необходимо сгенерировать запрос на получение, в котором будет содержаться вся информация о владельце домена и открытый ключ. После того, как запрос будет направлен в центр верификации, вы получите сертификат и файл с ключом. Важно сохранять этот файл в секрете. Стоимость таких сертификатов может быть довольно высокой, например, Symantec Secure Site Wildcard стоит примерно 281 967 рублей в год.
Не стоит экономить на обеспечении безопасности данных сайта. Гораздо проще потратить время и ресурсы на обеспечение безопасности, чем бороться с негативной репутацией после взлома сайта. Если ваш сайт связан с онлайн-торговлей, обеспечение его защиты должно быть вашим первостепенным приоритетом.
Это не полный список известных уязвимостей, а новые появляются все чаще и чаще. Сегодня мы остановимся только на одном типе уязвимости — небезопасной передаче данных и рассмотрим ключевые виды атак, связанных с ней. За последнее время, около 73% взломов сайтов, например, в мобильных банковских системах, были связаны с этой уязвимостью.
В интернете каждое действие является обменом данными. Когда пользователь заходит на сайт или отправляет сообщение в социальной сети, компьютер отправляет запрос серверу и получает ответ. Обычно, этот обмен осуществляется по протоколу HTTP. Протокол устанавливает правила обмена данными, и благодаря ему содержание сайта загружается на устройство.
Однако, хотя протокол HTTP очень удобен в использовании, данные, которые по нему передаются, абсолютно не защищены. Эти данные передаются в открытом виде. На пути от пользователя до сервера информация многократно проходит через различные промежуточные узлы. Если злоумышленник получит доступ к хотя бы одному из этих узлов, он сможет легко перехватить передаваемые данные. В корне уязвимости лежит небезопасность передачи данных и риски, связанные с этим важным моментом.
Ниже приведены некоторые из видов атак, вызванных небезопасной передачей данных:
Кража паролей - одно из самых распространенных преступлений в интернете. Какое-то время назад хакерская группировка CyberVor совершила огромный кражу. Они украли 4,5 миллиарда учетных записей, включая логины и пароли, с 420 000 веб-сайтов. Хакеры взломали множество ресурсов от крупных компаний до личных сайтов. По оценкам американской компании HoldSecurity, занимающейся информационной безопасностью, это самая большая база учетных данных, которая попала в руки преступников.
По статистике, каждый год 15% пользователей становятся жертвами мошенничества с кредитными картами или мошенничества с персональными данными. Одна из основных причин кражи - это кража паролей к аккаунту или административной части сайта. Кражка может произойти из-за вируса, устаревшей версии браузера, через который был введен пароль, или даже по причине легко подбираемого простого пароля.
Несмотря на реальную опасность хакерского вмешательства, многие владельцы сайтов используют не защищенные каналы аутентификации. Это означает, что пароли без труда могут быть перехвачены мошенниками.
Кража пароля дает хакерам доступ к сайту и информации о клиентах, что дает им большую возможность для мошенничества. Например, с сайта могут рассылаться спам-сообщения. Кроме этого, хакеры могут использовать информацию о клиентах с выгодой для себя, таким образом, украденные пароли могу быть использованы для снятия денег с банковских карт.
В то время как крупные компании, такие как банки, постоянно работают над защитой своих паролей, мелкие интернет-магазины, форумы, торрент-трекеры часто пренебрегают этим вопросом. Хакеры знают об этом и поэтому часто атакуют именно их.
В последнее время все чаще взломы сайтов происходят из-за ошибок хостинг-провайдеров. Это обусловлено тремя причинами.
Во-первых, причиной может быть устаревшее программное обеспечение, установленное на сервере. Это становится проблемой, так как взломщикам проще взломать сайт, работающий на устаревшей системе, чем на самой новой.
Во-вторых, взлом происходит через соседние аккаунты. В большинстве случаев сайты размещаются не на отдельных серверах, а на общих. Рядом с вашим сайтом может работать другой сайт, который не защищен. Как только он взломан, мошенник легко обращается к другим аккаунтам на сервере.
В-третьих, взлом может произойти из-за экономии на выборе хостинг-провайдера. Например, вы можете остановить свой выбор на услугах знакомого вам программиста, который будет отвечать за сервер. Но если он не компетентен в вопросах безопасности, сервер может быть взломан через уязвимые компоненты и настройки.
Недавно, в начале года, хакерская группировка взломала серверы Freedom Hosting II, специализирующегося на подпольном хостинге. В результате было скомпрометировано более 10 000 сайтов сети Tor, а также была похищена база данных, содержащая адреса электронной почты 381 000 пользователей.
Для управления контентом, структурой и дизайном сайта веб-мастера используют системы управления сайтом (Content Management System — CMS). Это простой и удобный способ создания, дизайна и обновления сайта даже для тех, кто не очень разбирается в программировании и веб-технологиях.
Однако, к сожалению, CMS, как и любое другое программное обеспечение, содержит уязвимости, которые могут быть использованы хакерами для взлома сайта. Эта угроза особенно актуальна для популярных систем, так как их взлом дает возможность атаковать несколько десятков тысяч сайтов по всему миру.
Согласно отчетам компании Sucuri, специализирующейся на веб-безопасности, в третьем квартале 2016 года самыми уязвимыми CMS были WordPress — 74%, Joomla — 17% и Magento — 6% от общего количества скомпрометированных сайтов. Большая часть взломов произошла из-за того, что администраторы не установили своевременно обновления безопасности системы.
Используя уязвимости CMS, хакеры могут размещать на сайте код с вредоносными программами, которые заражают компьютеры посетителей, публиковать контент сомнительного содержания или перенаправлять пользователя на другие сайты с подобным контентом. В результате сайт может потерять свою репутацию, что приведет к уменьшению количества посетителей.
Переформулируем заголовок: Как хакеры могут взломать сайт, используя модули и компоненты вне CMS
Признаем, что каждая из CMS прекрасно защищена от взлома, если установлена и настроена корректно. Однако, когда дело касается компонентов, плагинов и модулей от сторонних разработчиков, возникает новая угроза. Например, при установке расширения для комментариев, содержащего уязвимость, хакер может получить возможность вывести на сайте злонамеренный скрипт вместо комментария, что даст ему возможность осуществить взлом.
Уязвимость, известная как SQL-инъекция, возникает из-за недостаточной проверки и обработки переданных пользователем данных, что позволяет хакерам модифицировать и даже выполнять запросы, которые не предусмотрены кодом программы. В результате происходит нарушение доступа к данным, которые обычно недоступны.
Эта уязвимость открывает множество вариантов для хакеров, включая кражу, изменение или уничтожение данных и провоцирование отказа в обслуживании (DDoS). Предполагается, что громкие взломы последних лет, такие как утечка паролей с сайтов Yahoo, LinkedIn и eHarmony, могли быть осуществлены с помощью SQL-инъекций.
Отчет компании Akamai Technologies, Inc. показал, что в первом квартале 2016 года отмечен резкий рост атак, связанных с SQL-инъекциями - на 87% по сравнению с предыдущим периодом. Подавляющее большинство из них было направлено на сайты с медиа и контентом развлекательной тематики, а также на онлайн-сервисы и правительственные сайты.
Существует множество способов защиты от SQL-инъекций, в том числе и защита от каждого из конкретных типов. Это может включать использование лицензионного программного обеспечения, регулярное обновление системы управления контентом, использование надежных паролей и безопасных браузеров, а также введение межсетевых экранов. Одним из наиболее эффективных методов защиты является использование протокола https, и мы рассмотрим его подробнее ниже.
Как обеспечить защиту веб-сайта: преимущества протокола HTTPS
В современном мире, где технологии развиваются со столь быстротой, вопросы безопасности в сети становятся все более острой проблемой для владельцев сайтов. Часто на передовых позициях в этой борьбе находится протокол HTTPS.
HTTPS является защитной оболочкой для обычного HTTP, предназначенной для надежного шифрования передаваемой от пользователя к серверу и обратно информации. Данное шифрование исключает возможность утечки данных, что значительно повышает уровень безопасности сайта.
Важно отметить, что протокол HTTPS защищает не только данные пользователей, но и данные самого сайта, что делает его надежной защитой от взлома. Хотя такой протокол и требует некоторого усилия от владельца сайта и привязки к SSL-сертификату, эти затраты оправдывают себя защищенностью сайта и доверием пользующихся им пользователей.
В целом, использование протокола HTTPS может значительно повысить защиту сайта и сделать его более устойчивым к взлому.
Переход на https – необходимость или рекомендация?
Все сайты не обязаны переходить на https. Однако, если веб-ресурс работает с конфиденциальными данными клиентов, то использование защищенного протокола является обязательным. В остальных случаях решение о переходе на https принимает владелец сайта. Хотя утечка информации, которая может произойти в результате взлома, способна навредить любому веб-ресурсу: от рассылки спама до переходов на незащищенные сайты.
Кроме того, использование протокола https является большим плюсом для сайтов в глазах клиентов и пользователей. Они доверяют компании больше, когда соединение обеспечивает безопасность данных. Более того, сайты с защищенным соединением получают более высокую ранжировку в поисковых системах.
Фото: freepik.com