Как работает SSL и как установить его на сайт?

SSL TLS

Когда видите в адресной строке "https", это означает, что данные, которые отправляете и получаете от сайта, защищены. Этот знак сигнализирует, что сайт использует SSL/TLS сертификаты для шифрования.

В статье объясним, что такое SSL и TLS, зачем они нужны и как защищают данные юзеров на сайте.

Что такое SSL и TLS?

SSL (Secure Sockets Layer) и его преемник TLS (Transport Layer Security) — технологии, которые шифруют данные в интернете. Это значит, что информация, которую вы отправляете или получаете, защищена от посторонних глаз.

 

SSL

История и эволюция SSL/TLS

SSL разработан в компании Netscape в середине 1990-х. Это первая технология, которая шифровала данные между браузером и сервером. Было выпущено несколько версий SSL. Каждая из них улучшила безопасность и исправила уязвимости предыдущих.

Переход от SSL к TLS

TLS создан как усовершенствованная версия SSL. Он появился в 1999, чтобы устранить уязвимости и улучшить методы шифрования. TLS 1.0 стал первым стандартом после SSL 3.0 и с тех пор продолжает развиваться.

Почему TLS заменил SSL?

TLS заменил SSL, потому что давал более высокий уровень безопасности и исправил уязвимости SSL.

Как работает SSL-протокол?

SSL работает в несколько этапов:

  1. Рукопожатие — процесс, при котором браузер и сервер устанавливают защищённое соединение. Во время рукопожатия они договариваются о методах шифрования и обмениваются ключами.
  2. Шифрование. Данные шифруют, чтобы их не могли прочитать посторонние. Это делает информацию недоступной для злоумышленников.
  3. Расшифровка. Полученные данные расшифровываются на стороне получателя, чтобы они могли быть прочитаны.

Пример работы SSL с клиентом и сервером

Когда заходите на сайт с SSL, браузер и сервер обмениваются ключами для шифрования данных. Это гарантирует, что только вы и сайт можете читать информацию. Например, если вводите личные данные на сайте, они шифруются и передаются серверу в зашифрованном виде. Сервер расшифровывает данные и обрабатывает их.

Что такое SSL-сертификат?

SSL-сертификат содержит несколько ключевых элементов:

  • Открытый ключ. Используется для шифрования данных, которые можно расшифровать только с помощью закрытого ключа, хранящегося на сервере.
  • Подпись. Подтверждает, что сертификат выдан надежным удостоверяющим центром (CA) и не был подделан.

Почему сертификаты важны для безопасности?

Сертификаты обеспечивают, что вы общаетесь с тем сайтом, на который собирались зайти, а не с поддельным. Это подтверждает, что данные, которые отправляете, защищены и не будут перехвачены злоумышленниками.

Типы SSL-сертификатов

DV (Domain Validation)

Подтверждает только то, что вы владеете доменом. Это самый простой и быстрый вариант получения сертификата.

OV (Organization Validation)

Подтверждает вашу организацию и домен. Этот сертификат требует больше проверки, но обеспечивает больше доверия со стороны пользователей.

EV (Extended Validation)

Самый высокий уровень проверки, показывающий ваше название организации в адресной строке браузера. Подходит для крупных компаний и организаций, которым важен высокий уровень доверия.

Wildcard сертификаты

Позволяют защищать не только домен, но и все поддомены. Это удобно, если у вас много поддоменов, которые тоже должны быть защищены.

Multi-Domain SSL и UCC

Позволяют защитить несколько доменов одним сертификатом. Это экономит деньги и упрощает управление сертификатами.

Платные и бесплатные SSL-сертификаты

Платные сертификаты предлагают дополнительные функции, такие как более высокая степень проверки, поддержка и гарантии. Бесплатные сертификаты, например, от Let’s Encrypt, обеспечивают базовую защиту и подходят для большинства небольших сайтов.

let's encrypt

Как проверить, есть ли на сайте SSL-сертификат?

Есть несколько вариантов, как убедиться, что на сайте есть SSL-сертификат.

Первый —  посмотреть на индикаторы. Иконка замка и "https" в адресной строке браузера указывают на наличие SSL-сертификата. Это знак того, что соединение между браузером и сайтом защищено.

https

Также сайт можно проверить в SSL Checker.

Как получить SSL-сертификат?

Допустим, вы — владелец сайта и хотите установить SSL. Выберите провайдера сертификатов. Можно установить Let’s Encrypt или купить сертификат.

На примере покажем, как установить бесплатный сертификат Let’s Encrypt на свой сайт:

Первое: Установите Certbot

Certbot — инструмент от Let's Encrypt, который автоматически генерирует запрос и устанавливает сертификат. Для установки Certbot следуйте инструкциям для вашей ОС:

Для Ubuntu/Debian:

sudo apt update

sudo apt install certbot

Для CentOS/RHEL:

sudo yum install epel-release

sudo yum install certbot

Второе: Запустите Certbot

Используйте Certbot для создания запроса и получения сертификата. В зависимости от сервера команда может немного отличаться. Например:

Для Apache:

sudo certbot --apach

Для Nginx:

sudo certbot --nginx

Если не используете сервер, можно создать сертификат вручную:

sudo certbot certonly --standalone

Certbot попросит ввести данные: доменное имя и адрес электронной почты. После этого создаст запрос и отправит  в Let's Encrypt.

Третье: Установите сертификат

Certbot автоматически установит и настроит сертификат на сервере. Если этого не произошло, можете скопировать и установить сертификат вручную. Здесь вам помогут инструкции в документации Certbot.

Четвертое: Настройте автоматическое обновление

SSL-сертификаты от Let's Encrypt действуют 90 дней, поэтому нужно настроить автоматическое обновление. Для автоматического обновления сертификатов добавьте следующую строку в crontab:

0 0 * * * /usr/bin/certbot renew --quiet

Пятое: Подтвердите права на домен

Следуйте инструкциям провайдера для подтверждения того, что владеете доменом. Это может включать отправку подтверждающих документов или выполнение простых действий на сайте.

На этом все. Установка бесплатного сертификата от Let’s Encrypt закончена.

Не забывайте, что SSL/TLS сертификаты — как замок на двери дома. Если замок заржавел или сломался, его нужно заменить, чтобы защитить имущество. Точно так же важно следить за актуальностью сертификатов. Обновляйте их вовремя, чтобы избежать рисков и обеспечить безопасность данных пользователей.