Начав свой бизнес, настроив корпоративную почту (или рассылки) и не получив никакого эффекта или результата по причине того, что все письма валятся в спам или вообще не доходят, мы сразу начинаем беспокоиться и задаваться вопросами: «А в чем дело? А как проверить настройку почты? А все ли мне верно настроили?». Пара запросов в любимый всеми Библиотека телефонных номеров Google с фразами «проверить почтовый сервер» или «проверка почтовой службы», а если продвинутый то и «проверить MX-записи», даст нам несколько ссылок, где можно посмотреть те самые настройки.
Вводим наш домен. И на выходе куча пунктов, среди которых: «Запись DMARC не настроена.»
«Запись DKIM не настроена.», «Запись SPF не настроена.». WTF??? По русски: Это че такое?
Итак, поясняем!
Как вы помните из прошлых статей, то особой безопасностью SMTP протокол не отличается. Грубо говоря, при определенных условиях спамер может отправить почту от кого угодно, кому угодно. Хоть [email protected] от [email protected].
Как же серверу whitehouse.gov быть уверенным, что он получает почту именно от kremlin.ru? А как kremlin.ru быть уверенным, что от его имени никто не отправит почту? Вот именно для этого и существует средство под названием Sender Policy Framework (инфраструктура политики отправителя) или SPF.
Как это работает? Да очень просто: kremlin.ru должен указать сервера,
с которых он разрешает отправить почту! А whitehouse.gov должен иметь возможность это проверить при приеме почты! Как же это сделать? Эх… да через настройки домена kremlin.ru, как еще?!
Как же это все выглядит:
Запись: “v=spf1 ip4:5.5.5.5 -all” в домене kremlin.ru говорит, о том что доверять стоит только той почте, которая приходит с ip-адреса 5.5.5.5, а все остальное скорее всего (уж простите) фуфло. Таких моментов может быть много, а именно: “v=spf1 ip4:5.5.5.5 ip4:4.4.4.4 -all”, тут к прошлому адресу еще один добавился – 4.4.4.4.
SPF запись прописывается в настройках домена. Соответственно, доступы к домену есть только у владельца. Там прописывается данная запись, которая указывает на IP адрес сервера. Если к примеру меняется сервер (соответственно и IP адрес), то нужно просто изменить IP в записи на новый.
Разобрались?
А что должен сделать whitehouse.gov, если примет почту от адреса, которого нет в SPF kremlin.ru? По умолчанию присвоить большую оценку спамовости. Внести в «черный список» по идее. Но есть еще пара моментов, о которых уже в третьей части этой статьи.
Часть 2 – DKIM
Итак, кроме того, что whitehouse.gov проверяет конкретный ip-адрес сервера, который доставил почту с kremlin.ru, как же ему быть еще уверенным, что:
- письмо именно с kremlin.ru (если оно идет через промежуточные какие-то сервера, ведь тогда SPF не сработает);
- письмо никто не поменял в процессе доставки (если оно шло через промежуточные сервера).
Для этого придумали отдельный механизм DomainKeys Identified Mail (почта, идентифицируемая по доменным ключам) или DKIM. Вы слышали об электронной цифровой подписи (ЭЦП)? Открытых и закрытых ключах? Если да, то пропускайте следующий абзац, если нет, то читайте.
Что такое открытый и закрытый ключ? – Это понятия из криптографии. Основываясь на некоторых математических свойствах и приколах, механизм работает так:
- У вас есть ваш открытый ключ (набор символов), который вы дали кому либо;
- У вас есть ваш закрытый ключ, который знаете только вы;
- Вы берете текст и зашифровываете его закрытым ключом;
- По воле богов математики расшифровать его можно только ОТКРЫТЫМ ключом и ничем более;
- Вы отправляете текст вашему адресату, он расшифровывает его открытым ключом и все довольны.
Что же это дает? А то, что:
- Когда нам важна секретность (конфиденциальность) сообщения: чтобы никто не прочитал! Если кто-то в процессе передачи повредит или изменит зашифрованный текст, Данные Великобритании то расшифровка не получится! И ваш получатель сразу поймет, что дело нечисто, и кто-то между вами чего то там мутит. Т.е. линия ненадежна.
- Но теперь, допустим, нам не важна конфиденциальность. Хрен с ним. Хай читают. Вот абы не меняли: если отправить просто текст вместе с зашифрованным текстом, то получим как раз ЭЦП! Т.е. наш получатель получает открытый и зашифрованный тексты, расшифровывает шифр и сравнивает результаты с открытым текстом. Если не совпадают – кто-то менял открытый текст по пути! Т.е. когда все получилось, то получатель уверен, что: сообщение отправляли именно вы, его по пути не поменяли и не повредили.
Понятно? Вот так и работает DKIM.
Есть два ключа. Один закрытый, лежит на сервере почтовом, второй открытый – доступен в DKIM-записи домена. Причем прикол в том, что таких ключей может быть много! Т.е. каждый отдел в вашей компании может иметь свой ключ, а может и каждый сервер свой отдельный ключ иметь, а может и каждый сотрудник своим ключом подписывать (но это уже точно у кого-то из ваших паранойя в последней стадии ибо столько ключей в домене прописывать – брррр! )
И вот, получает whitehouse.gov письмо от kremlin.ru, а в письме еще подпись какая то. Берет он и тянет доменную DKIM запись для kremlin.ru, проверяет подпись, сошлось? Если да – все норм! Если нет – это уже вопрос. По умолчанию – добавить спамовости.
А теперь представим ситуацию, что сервера kremlin.ru (ну чисто теоретически) очень часто отправляют почту через промежуточные сервера, но всегда подписывают? И если whitehouse.gov получил письмо, правильно подписанное DKIM, Хочу всегда во “Входящие” но не совпадающими SPF, то его ни в коем случае не рекомендуется слать в спам?
А может быть , что так много серверов, просто не успеваем ключи заносить всегда, но всегда доставка идет с серверов правильных SPF-записей? Данные по Тайваню Т.е. с верных адресов, но без подписи? И тоже в этом случае не рекомендуется слать в спам?