Как отправить письмо на smtp сервер

В некоторых случаях с целью тестирования или диагностики работы почты, почтовому администратору требуется проверить отправку писем через свои сервера Exchange (и не только) с определенных хостов. В том случае, если сервер не требует авторизации (open-relay сервер), отправить почту можно . Однако в большинстве случае почтовые сервера для отправки почты требуют авторизации. В этом примере мы покажем, как в консоли telnet выполнить аутентификацию типа AUTH LOGIN на SMTP сервере и отправить письмо.

AUTH LOGIN – в терминологии Exchange – это базовая аутентификация, когда имя и пароль пользователя передаются по сети в закодированном по алгоритму base64 виде. На большинстве внутренних серверах Exchange администраторы не отключают Basic Authentication . Проверить ее поддержку можно в настройках принимающего коннектора.

Примечание . Обращаем ваше внимание что злоумышленник при доступе к каналу связи может легко перехватить и расшифровать закодированные по Base64 учетные данные пользователя. Поэтому этот способ авторизации рекомендуется использовать исключительно в частных корпоративных сетях.

Для авторизации на почтовом сервер с с помощью AUTH LOGIN, нам нужно преобразовать имя и пароль пользователя, из-под которого будет отправляться письмо в формат Base64. Это можно сделать с помощью скриптов или онлайн сервисов. Я воспользоваться сайтом https://www.base64encode.org/ .

Имя пользователя: testuser@ contoso. com , в кодировке Base64 получилось: dGVzdHVzZXJAY29udG9zby5jb20=

Пароль: $ up3 RsTr) ng — в Base64 JHVwM1 JzVHIpbmc=

Теперь в командой строке с помощью Telnet подключаемся на 25(SMTP) порт нашего почтового сервера (вводимые команды я буду выделять синим цветов):

telnet mail.contoso.com 25

Если это Exchange, он вернет что-то вроде;

Представимся:

ehlo sender.contoso.com

Сервер вернет список поддерживаемых типов авторизаций и возможностей. Как вы видите базовая авторизация (AUTH LOGIN) в списке имеется.

250-mail.contoso.com Hello
250-SIZE 36700160
250-PIPELINING
250-DSN
250-ENHANCEDSTATUSCODES
250-STARTTLS
250-AUTH LOGIN
250-8BITMIME
250-BINARYMIME
250 CHUNKING

AUTH LOGIN

Сервер должен ответить:
334 VXNlcm5hbWU6

Теперь вставляем имя пользователя в формате Base64, которое мы закодировали ранее:
dGVzdHVzZXJAY29udG9zby5jb20=

Сервер должен ответить:

334 UGFzc3dvcmQ6.

Теперь пора вставить пароль в формате Base64:
JHVwM1JzVHIpbmc=

Если имя и пароль пользователя верны, сервер ответит.
235 2.7.0 Authentication successful

Если нет:

535 5.7.8 Error: authentication failed: UGFzc3dvcmQ6

Теперь можно заполнить стандартные поля письма:

mail from: [email protected]
250 2.1.0 Sender OK
rcpt to: [email protected]
250 2.1.5 Recipient OK
data
354 Start mail input; end with .
from: TestUserovich
to: TheAdmin < [email protected] >
Subject: Test BASE SMTP Authenticated via Telnet
This is test
.
250 2.6.0 Queued mail for delivery

QUIT

221 2.0.0 Closing connection.
Connection closed by foreign host.

На этом все, тестовое письмо должно успешно доставиться в ящик получателя.

Включите эту опцию, если сообщения с почтовых доменов MDaemon должны отправляться только авторизованными пользователями. При попытке отправить такое сообщение без предварительной авторизации MDaemon откажется принять сообщение для доставки. Эта опция включена по умолчанию .

Только если сообщение не отправлено на локальную уч. запись

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

Включите эту опцию, чтобы обеспечить обязательную авторизацию отправителя при получении входящих сообщений с локальных IP-адресов. В случае неудачной авторизации сообщение будет отклонено. Адреса из списка доверенных IP освобождаются от проверки. Данная опция включена по умолчанию только в недавно установленных экземплярах сервера.

Данные проверки подлинности должны совпадать со значением "return-path"

По умолчанию, данные используемые для SMTP-авторизации должны совпадать с адресом, указанным в заголовке "return-path". Отключите эту опцию, если данное совпадение не является обязательным условием. Во избежание проблем с хранением и перенаправлением почты шлюза, на экране Глобальные настройки шлюза доступна опция " умолчанию .

Данные проверки подлинности должны совпадать с адресом в заголовке "From:"

По умолчанию, данные используемые для SMTP-авторизации должны совпадать с адресом, указанным в заголовке "From:". Отключите эту опцию, если данное совпадение не является обязательным условием. Во избежание проблем с хранением и перенаправлением почты шлюза, на экране Глобальные настройки шлюза доступна опция " Исключить почту шлюза из проверки на совпадение данных авторизации AUTH" включенная по умолчанию .

Требовать авторизацию для почты от " Postmaster " , " abuse " , " webmaster "

Выберите эту опцию для требования авторизации сообщений от псевдонимов или учетных записей “postmaster@...”, “abuse@...” или “webmaster@...” перед тем, как их примет MDaemon. Спамеры и хакеры знают о существовании таких адресов и могут попытаться использовать один из них для отправки почты через вашу систему. Эта опция позволит избежать этого. Эта опция также дублируется на вкладке настройки псевдонимов - вы можете включать или отключать ее и там, и там.

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

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

Как отправлять письма, используя PHP?

С помощью любого класса PHP, поддерживающего авторизацию на smtp-сервере . Например, можно использовать набор классов PHPMailer.

Также вы можете воспользоваться нашим примером, в котором реализована отправка писем с использованием smtp-сервера , для которого требуется авторизация. Поэтому не забудьте добавить в скрипт соответствующие реквизиты доступа, например:

// Если нужно показать лог SMTP-сессии, то можно раскомментировать следующую строчку. // $_SERVER["debug"] = true; function MailSmtp ($reciever , $subject , $content , $headers , $debug = 0 ) { $smtp_server = "smtp.сайт" ; // адрес SMTP-сервера $smtp_port = 25 ; // порт SMTP-сервера $smtp_user = "[email protected]" ; // Имя пользователя для авторизации на SMTP-сервере $smtp_password = "pAsSwORd" ; // Пароль для авторизации на SMTP-сервере $mail_from = "[email protected]" ; // Ящик, с которого отправляется письмо $sock = fsockopen ($smtp_server , $smtp_port , $errno , $errstr , 30 ); $str = fgets ($sock , 512 ); if (! $sock ) { printf ("Socket is not created\n" ); exit(1 ); } smtp_msg ($sock , "HELO " . $_SERVER [ "SERVER_NAME" ]); smtp_msg ($sock , "AUTH LOGIN" ); smtp_msg ($sock , base64_encode ($smtp_user )); smtp_msg ($sock , base64_encode ($smtp_password )); smtp_msg ($sock , "MAIL FROM: <" . $mail_from . ">" ); smtp_msg ($sock , "RCPT TO: <" . $reciever . ">" ); smtp_msg ($sock , "DATA" ); $headers = "Subject: " . $subject . "\r\n" . $headers ; $data = $headers . "\r\n\r\n" . $content . "\r\n." ; smtp_msg ($sock , $data ); smtp_msg ($sock , "QUIT" ); fclose ($sock ); } function smtp_msg ($sock , $msg ) { if (! $sock ) { printf ("Broken socket!\n" ); exit(1 ); } if (isset($_SERVER [ "debug" ]) && $_SERVER [ "debug" ]) { printf ("Send from us: %s
" , nl2br (htmlspecialchars ($msg ))); } fputs ($sock , " $msg \r\n" ); $str = fgets ($sock , 512 ); if (! $sock ) { printf ("Socket is down\n" ); exit(1 ); } else { if (isset($_SERVER [ "debug" ]) && $_SERVER [ "debug" ]) { printf ("Got from server: %s
" , nl2br (htmlspecialchars ($str ))); } $e = explode (" " , $str ); $code = array_shift ($e ); $str = implode (" " , $e ); if ($code > 499 ) { printf ("Problems with SMTP conversation.

Code %d.
Message %s
"
, $code , $str ); exit(1 ); } } } ?>

Скачать пример готового скрипта с функцией MailSmtp(): smtpauth.php.sample

Использовать описанную выше функцию MailSmtp() можно для прямой замены функции mail(), рассмотрим пример самой простой формы на PHP:

// Заголовки сообщения, в них определяется кодировка сообщения, поля From, To и т.д. $headers = "MIME-Version: 1.0\r\n" ; $headers .= "Content-type: text/html; charset=windows-1251\r\n" ; $headers .= "To: $to \r\n" ; $headers .= "From: Имя отправителя " ; // mail ($to, $subject, $message, $headers); require_once "smtpauth.php" ; MailSmtp ($to , $subject , $message , $headers ); } ?>
Кому: 
 Тема: 
 Текст: 
 
 

Для того, чтобы данная форма заработала без функции mail(), мы включили файл smtpauth.php через require_once и вызвали функцию MailSmtp(), описанную в нем, с аналогичными для mail() аргументами. При этом сам вызов mail() мы закомментировали в коде, чтобы избежать ошибки при выполнении скрипта.

Как отправлять письма, используя ASP.NET?

Если вы используете версию 2.0, то используя класс MailMessage System.Net.Mail ), хорошо описанный .

Ниже приведены примеры его использования для языков «C#» и «VisualBasic»:

Пример для языка «C#»:

<% @Page Language="c#" %> <% @Import Namespace="System.Net.Mail" %> <% @Import Namespace="System.Net" %> <% MailMessage message = new MailMessage(); // создание нового письма message.To.Add ("[email protected]"); // добавление адреса получателя message.From = new MailAddress("from@domain.tld ", "Имя_отправителя"); // указание имени и адреса отправителя message.Subject = "Тема письма"; // указание темы письма message.BodyEncoding = System.Text.Encoding.UTF8; // указание кодировки письма message.IsBodyHtml = false; // указание формата письма (true - HTML, false - не HTML) message.Body = "Текст письма"; // указание текста (тела) письма SmtpClient client = new SmtpClient("smtp.сайт",25); // создание нового подключения к серверу "smtp.сайт" client.DeliveryMethod = SmtpDeliveryMethod.Network; // определяет метод отправки сообщений client.EnableSsl = false; // отключает необходимость использования защищенного соединения с сервером client.UseDefaultCredentials = false; // отключение использования реквизитов авторизации "по-умолчанию" client.Credentials = new NetworkCredential("postmaster@domain.tld ", "***password***"); // указание нужных реквизитов (имени пользователя и пароля) для авторизации на SMTP-сервере client.Send(message); // отправка сообщения %>

Скачать пример готовой формы, демонстрирующей использование данного метода: MailForm.aspx .

Пример для языка «VisualBasic»:

<% @Page Language="VB" Debug="true" %> <% @Import Namespace="System.Net.Mail" %> <% @Import Namespace="System.Net" %> <% Dim smtpMssg AS new MailMessage smtpMssg.From = New MailAddress ("admin@domain.tld ", "Имя_отправителя") smtpMssg.To.Add ("[email protected]") " добавление адреса получателя smtpMssg.Subject = "Тема письма" " указание темы письма smtpMssg.Body = "Текст письма" " указание текста (тела) письма smtpMssg.BodyEncoding = System.Text.Encoding.UTF8 " указание кодировки письма smtpMssg.IsBodyHtml = false " указание формата письма (true - HTML, false - не HTML) Dim SmtpMail As New SmtpClient("smtp.сайт", 25)" объявление нового объекта типа "SmtpClient" SmtpMail.DeliveryMethod = SmtpDeliveryMethod.Network " указание метода доставки письма SmtpMail.UseDefaultCredentials = False " отключение использования реквизитов авторизации "по-умолчанию" SmtpMail.EnableSsl = False " отключает необходимость использования защищенного соединения с сервером SmtpMail.Credentials = new NetworkCredential("postmaster@domain.tld ", "***password***") " указание нужных реквизитов (имени пользователя и пароля) для авторизации на SMTP-сервере SmtpMail.Send(smtpMssg) " отправка сообщения %>

Также существует устаревший (и не рекомендуется к использованию) класс SmtpMail (используется пространство имен System.Web.Mail ). Ниже приведен пример его использования для языка «VisualBasic»:

<% @Page Language="VB" Debug="true" %> <% @Import Namespace="System.Web" %> <% @Import Namespace="System.Web.Mail" %> <% Dim smtpMssg = new MailMessage " объявление нового объекта типа "MailMessage" smtpMssg.From = "Имя_отправителя domain.tld >" " указание имени и адреса отправителя smtpMssg.To = "admin@domain.tld " " указание адреса получателя smtpMssg.BodyFormat = MailFormat.Text " указание формата письма smtpMssg.BodyEncoding = Encoding.UTF8 "указание кодировки письма smtpMssg.Subject = "Тема письма" " указание темы письма smtpMssg.Body = "Текст письма" " указание текста письма smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate",1) " указание необходимости SMTP-авторизации на сервере smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendusername", "admin@domain.tld ") " имя пользователя для авторизации smtpMssg.Fields.Add("http://schemas.microsoft.com/cdo/configuration/sendpassword", "***password***") " пароль для авторизации SmtpMail.SmtpServer = "smtp.сайт" " указание адреса SMTP-сервера SmtpMail.Send(smtpMssg) " отправка сообщения %>

Как отправлять письма, используя ASP?

Обратите внимание, что при использовании нашего smtp-сервера требуется авторизация, поэтому не забудьте добавить в скрипт соответствующие реквизиты доступа, например:

<% iConfig = Server.CreateObject("CDO.Configuration") Set iConfig = Server.CreateObject("CDO.Configuration") With iConfig.Fields .Item("http://schemas.microsoft.com/cdo/configuration/smtpserver") = "smtp.сайт" .Item("http://schemas.microsoft.com/cdo/configuration/smtpserverport") = 25 .Item("http://schemas.microsoft.com/cdo/configuration/sendusing") = 2 .Item("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate") = 1 .Item("http://schemas.microsoft.com/cdo/configuration/languagecode") = "ru" .Item("http://schemas.microsoft.com/cdo/configuration/sendusername") = "postmaster@domain.tld " .Item("http://schemas.microsoft.com/cdo/configuration/sendpassword") = "password" .Update End With Set cdoMessage = CreateObject("CDO.Message") With cdoMessage Set .Configuration = iConfig .From = "Test user domain.tld >" .To = "User " .Subject = "Hello, User" .TextBody = "I write this message from ASP script." .Send End With Set cdoMessage = Nothing Set iConfig = Nothing %>

Некоторые CMS уже имеют встроенные средства для отправки корреспонденции или соответствующие модули, рассмотрим самые популярные из них.

Wordpress

Для данной CMS существует специальный модуль «WP Mail SMTP », пример его конфигурации описан на странице модуля .

Обратите внимание на иллюстрацию в примере, в условиях нашей почтовой системы требуется использовать 25-й порт и SSL-шифрование не требуется.

Joomla

В панели администрирования перейдите в раздел «Общие настройки», выберете вкладку «Сервер». В поле «Почта» требуется выбрать способ отправки как «SMTP-сервер », в полях «Адрес SMTP-сервера » и «SMTP-логин » и «SMTP-пароль » укажите соответствующие реквизиты почтовой системы, например: smtp.сайт, ящик@ваш_домен и соответствующий пароль.

Drupal

Эта CMS так же имеет собственный модуль для работы с SMTP-сервером , основанный на базе PHPMailer. Загрузить данный модуль можно на его странице на сайте CMS Drupal, описание установки модуля доступно в архиве с ним.

NetCat

Данная CMS не имеет встроенных функций для работы с SMTP-сервером . Для отправки почты скриптами сайта мы можем предложить использовать наше решение, для его подключения необходимо выполнить следующие действия:

  • Скачать с нашего сайта архив с необходимыми файлами (send_auth_mail.php и mail.inc.php ) и распаковать его на компьютере;
  • Отредактировать файл send_auth_mail.php из архива, указав в нём реквизиты подключения к нужному SMTP-серверу:

    • $mail_smtpServer = "smtp.сайт" ; (адрес SMTP-сервера )
    • $mail_port = "25" ; (порт для подключения)
    • $mail_username = "[email protected]" ; (имя пользователя для авторизации на SMTP-сервере )
    • $mail_password = "Password" ; (пароль для авторизации на SMTP-сервере )
  • Создать резервную копию файла domain.tld/www/netcat/admin/mail.inc.php ;
  • Загрузить файлы send_auth_mail.php и mail.inc.php на виртуальную площадку в директорию domain.tld/www/netcat/admin/

domain.tld следует заменить на имя вашего домена.

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