Рис.1 HTML-код формы обратной связи
Как в итоге выглядит приведенная здесь форма обратной связи, можно посмотреть на следующем скриншоте.
Таким образом нужная форма создана. И теперь можно перейти к вопросам обработки и отправки данных в виде почтового сообщения.
Устанавливаем библиотеку PHPMailer
Как ранее отмечалось, для отправки почты мы будем использовать библиотеку PHPMailer, которая позволит существенно упростить отправку email через протокол SMTP с авторизацией на стороннем почтовом сервисе.
Для ее установки требуется скачать необходимые файлы. Это можно сделать с веб-сервиса GitHub,
используя для этого Composer (пакетный менеджер зависимостей для PHP). Либо просто, скачать необходимые файлы обычным образом.
скриншот 73
Ниже показана страница веб-сервиса GitHub, где отмечена ссылка на обычное скачивание библиотеки PHPMailer.
Кроме этого, последнюю версию 6.0.7, которая была сохранена на момент написания данной статьи, можно скачать из прилагаемых материалов .
В любом случае полученный архивный файл следует распаковать, после чего извлеченную папку PHPMailer-master со всем содержимом поместить в корень сайта. При этом, для простоты, можно ее переименовать в PHPMailer. Ниже показано содержимое папки PHPMailer, помещенной в корневой каталог сайта.
Таким образом мы установили библиотеку PHPMailer. После чего можем заняться формированием скрипта, с помощью которого будем отправлять с нашего сайта почтовые сообщения.
Формируем скрипт отправки почты через SMTP
Для составления скрипта вполне достаточно воспользоваться рекомендациями по применению PHPMailer, приведенными на странице GitHub, которую ранее мы использовали для скачивания библиотеки.
В них, в частности указывается, что в начале скрипта требуется импортировать классы PHPMailer в глобальное пространство имен. И даны конкретные строки соответствующего кода. А также приведены примеры использования свойств и методов PHPMailer, в том числе и для варианта отправки почты через SMTP.
Но если этого будет недостаточно, то можно воспользоваться и документаций,
в которой имеется описание всех свойств и методов данной библиотеки.
скриншот 74
Ниже приведен код скрипта отправки почты из формы обратной связи через SMTP с авторизацией. Где все строки, относящиеся к PHPMailer, даны с пояснения и выделены светлым фоном.
Остальная часть, включая фрагменты, касающиеся получения и обработки данных из формы, которые нам ранее уже приходилось использовать в других обработчиках, обозначены темным фоном. Достаточно подробно о них говорилось ранее в
статье , посвященной, как раз, вопросам получения и проверке данных из формы в PHP. Где также рассказывалось об универсальной пользовательской функции проверки и обработки данных формы check_symbol()
.
Данный скрипт разместим в том же файле kontakty.php, в котором ранее мы сформировали форму обратной связи.
//----Скрипт отправки почты через SMTP с использованием PHPMailer----
//Импорт классов PHPMailer в глобальное пространство имен. Они должны быть в верхней части скрипта, а не внутри функции
use
PHPMailer\PHPMailer\PHPMailer
;
use
PHPMailer\PHPMailer\Exception
;
if
(!empty
($_POST["contact-button"
])) {
$name = $_POST["contact-name"
];
$name = check_symbol
($name, "Имя"
, "1"
, "/^+\z/iu"
);
$email = $_POST["contact-email"
];
$email = check_symbol
($email, "E-mail"
, "1"
, "/^+@(+\.)+{2,6}\z/i"
);
$subject = $_POST["contact-subject"
];
$subject = check_symbol
($subject, "Тема сообщения"
, "1"
, "0"
);
$comment = $_POST["contact-comment"
];
$comment = check_symbol
($comment, "Текст сообщения"
, "1"
, "0"
);
if
(!empty
($GLOBALS["alert"
])) {
$alert = "Данные из формы не отправлены. Обнаружены следующие ошибки: \n"
.$alert;
include
"alert.php"
;
else
{
//Подключение библиотеки
require
"PHPMailer/src/PHPMailer.php"
;
require
"PHPMailer/src/Exception.php"
;
require
"PHPMailer/src/SMTP.php"
;
$mail = new
PHPMailer
(); //Инициализация класса
$from = "[email protected]"
; //Адрес почты, с которой идет отправка письма
$to = "[email protected]"
; //Адрес получателя
$mail -> isSMTP
(); //Применение протокола SMTP
$mail -> Host
= "smtp.yandex.ru"
;//Адрес почтового сервера
$mail -> SMTPAuth
= true
; //Включение режима авторизации
$mail -> Username
= "[email protected]"
; //Логин от доменной почты, подключенной к стороннему почтовому сервису (в данном случае в Яндекс.Почта)
$mail -> Password
= "27MrDon89"
; //Пароль от доменной почты
$mail -> SMTPSecure
= "ssl"
; //Протокол шифрования
$mail -> Port
= "465"
; //Порт сервера SMTP
$mail -> CharSet
= "UTF-8"
; //Кодировка
$mail -> setFrom
($from, "Администратор"
); //Адрес и имя отправителя
$mail -> addAddress
($to, "Администратор"
); //Адрес и имя получателя
$mail -> isHTML
(true
); //Установка формата электронной почты в HTML
$mail -> Subject
= "Отправлена форма обратной связи"
; //Тема письма (заголовок)
$mail -> Body
= "
Имя отправителя: $name
Адрес отправителя: $email
Тема сообщения: $subject
Содержание сообщения: $comment
"
; //Содержимое письма
$mail -> AltBody
= "Текст альтернативного письма"
; //Альтернативное письмо в случае, если почтовый клиент не поддерживает формат HTML
$mail -> SMTPDebug
= 0
; //Включение отладки SMTP: 0 - выкл (для штатного использования), 1 = сообщения клиента, 2 - сообщения клиента и сервера
if
($mail -> send
()) {
$alert = "Сообщение отправлено"
; //Вывод сообщения в диалоговом окне браузера об успешной отправке письма
else
{
$alert = "Ошибка, письмо не может быть отправлено: "
.$mail -> ErrorInfo
; //Вывод сообщения об ошибке
include
"alert.php"
;
Рис.5 Скрипт для отправки email через SMTP с авторизацией
Как видно, все строки, относящиеся непосредственно к отправке почтового сообщения, в которых заданы необходимые методы и свойства, сопровождаются комментариями. Поэтому не имеет смысла повторяться, а можно остановиться только на некоторых из них, действительно, требующих дополнительные пояснения, а именно:
1. В связи с тем, что письмо оправляется со стороннего почтового сервиса, то здесь применены настройки, соответствующие конкретному SMTP серверу. В данном случае, для варианта использования сервера Яндекс.Почта применены следующие значения свойств:
- Свойство Host
(поз.28) - Адрес почтового сервера со значением smtp.yandex.ru;
- Свойство SMTPSecure
- Свойство Port
Эти значения свойств были взяты со страницы Яндекс.Помощь, приведенной на следующем скриншоте.
Но такую информацию можно получить и из других ресурсов. Для этого достаточно в поисковике ввести соответствующий запрос, например: "smtp сервер яндекс". Где можно найти большое количество ссылок по этому вопросу.
Аналогичным образом значения настроек можно получить и по другим SMTP серверам. Ниже показан скриншот страницы Помощи Mail.ru, где отображены настройки SMTP сервера почтового сервиса Mail.ru.
И таким образом, в случае использования в качестве стороннего SMTP сервера Mail.ru, должны быть применены следующие значения свойств класса PHPMailer:
- Свойство Host
(поз.28) - Адрес почтового сервера (smtp.mail.ru);
- Свойство SMTPSecure
(поз.32) - Протокол шифрования (ssl);
- Свойство Port
(поз.33) - Порт сервера SMTP (465).
Подобный подход следует применять и для других почтовых сервисов.
2. В свойстве Username
(поз.30) необходимо указывать полный адрес почтового ящика доменной почты. В данном случае в качестве логина от почтового ящика, с которой идет отправка писем, используется "[email protected]".
Однако, если для отправки писем использовать учетную запись не доменной почты, а адрес, относящийся непосредственно к почтовому сервису, например "[email protected]", то тогда логином должна является только часть адреса до знака "@". В этом случае логин имел бы значение "feedback".
3. В PHPMailer предусмотрено свойство SMTPDebug
(поз.50), которое позволяет отображать на экране браузера различный уровень ошибок. Такая возможность значительно упрощает нахождение проблем при отладке скрипта.
Обычно, в штатном режиме, при установленном значении 0, вывод подробной информации об ошибке отключен. Но при возникновении проблем с отправкой почты, либо при отладке, для вывода более содержательной информации об ошибке, возможно использовать другие значения.
Для того, чтобы посмотреть, как это выглядит на практике, временно внесем в настройки какую-нибудь ошибку. Например, в пароль от доменной почты (свойство Password
, поз.31). А также для вывода подробной информации об ошибке, временно установим в свойстве SMTPDebug
(поз.50) значение 1. После, когда все будет отлажено и проверено, отключим режим отладки SMTP, заменив 1 на 0.
В завершающей части скрипта, после указания всех необходимых свойств и методов, для отправки письма применен метод send()
) (поз.51). И если письмо будет отправлено, и метод send()
для объекта $mail
вернет true, то в диалоговом окне браузера через переменную $alert
будет выведено сообщение об успешной отправке почты (поз.52).
В случае же, если почта по каким-либо причинам не смогла быть отправлена, и соответственно, метод не смог вернуть истину, то такое состояние будет сопровождаться соответствующим сообщением об ошибке (поз.55).
Проверяем отправку email
После того, как мы составили скрипт отправки почты, естественно, нужно посмотреть на результат нашего "творчества". Все ли мы здесь учли, и не наделали ли каких-либо ошибок.
Для этого попробуем, как и было задумано, отправить из формы обратной связи сообщение от пользователя администратору сайта. Ниже показан скриншот формы обратной связи с заполненными полями до ее отправки.
А здесь показан результат отправки формы.
Где, из сообщения в диалоговом окне браузера видно, что письмо не может быть отправлено в связи с проблемой соединения по SMTP.
Но, так как сейчас свойству SMTPDebug
(поз.50) присвоено значение 1, то мы сможем посмотреть подробную информацию о возникшей ошибки и выяснить причину ее возникновения.
На следующем скриншоте видно, что при попытке соединения обнаружена ошибка аутентификации, означающая использование неправильного логина или пароля.
После устранения несоответствия пароля (ранее использовался неправильный пароль для возможности проверки вывода дополнительной информации об ошибке), снова попытаемся отправить почту.
На этот раз, как будто, все прошло удачно, и мы получили сообщение об успешной отправке почты. По всей видимости, кроме заведомо введенной временной ошибки в пароль от доменной почты, никаких других оплошностей мы не допустили.
Но для того, чтобы убедиться, что письмо действительно было доставлено до адресата, войдем в почту с адресом [email protected] и посмотрим на результат.
Как видно, письмо с адреса [email protected], с которого мы отправляли почтовое сообщение с именем "Обратная связь" до администратора сайта благополучно дошло. При этом в теле письма имеется все то содержимое, которое мы формировали в скрипте с использованием данных, полученных из формы обратной связи, а именно:
- Имя отправителя: Николай;
- Адрес отправителя: [email protected];
- Тема сообщения: Проверка отправки почты;
- Содержание сообщения: Тестовое сообщение.
Теперь, после успешной проверки отправки почты можно будет отключить режим отладки SMTP, назначив свойству SMTPDebug
(поз.50) значение 0.
Таким образом мы выполнили задачу по созданию инструмента отправки почты через SMTP с авторизацией с использованием стороннего почтового сервера.
Например, в следующей статье мы посмотрим, как отправлять подтверждающие письма для восстановления данных учетной записи зарегистрированного пользователя.
Исходные файлы сайта
Исходные файлы сайта с обновлениями, которые были сделаны в данной статье, можно скачать из прилагаемых дополнительных материалов:
- Файлы каталога www
- Таблицы базы данных MySQL
В некоторых случаях с целью тестирования или диагностики работы почты, почтовому администратору требуется проверить отправку писем через свои сервера 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.
На этом все, тестовое письмо должно успешно доставиться в ящик получателя.
Поскольку отправка анонимных сообщений с серверов виртуального 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-сервером
. Для отправки почты скриптами сайта мы можем предложить использовать наше решение, для его подключения необходимо выполнить следующие действия:
domain.tld
следует заменить на имя вашего домена.
Предлагаемое решение работает со всеми модулями NetCat, которые используют стандартные функции данной CMS для отправки почты.
Отправка почты через SMTP с локального сервера позволяет протестировать отправку сообщений с сайта находящемся на локальной машине, или проще говоря, локальном сервере. Для этого можно использовать любой почтовый сервис yandex, google или mail.ru.
Прежде всего, SMTP (Simple Mail Transfer Protocol) - это широко используемый сетевой протокол, предназначенный для передачи электронной почты в сетях TCP/IP. И такими протоколами обладают все популярные почтовые сервисы.
С появлением локальных серверов, отпала необходимость выбора хостинг-провайдера для того чтобы проверить работоспособность отдельных скриптов или cms-систем, а тем более еще и платить за это. Гораздо проще все протестировать на компьютере, ну а затем можно и показать всем что «натворили».
Многие такие сервера имеют уже встроенное программное обеспечение и необходимый функционал по работе с почтой, нужно его только правильно настроить.
Для проверки работоспособности такой почты необходим самый минимум:
- В качестве локального сервера можно использовать Openserver.
- И простенький скрипт, шаблон которого можно взять чуть ниже.
- Почтовый сервер можно использовать любой.
Отправка почты php через SMTP-настройка скрипта
Шаблон простенького скрипта который можно скопировать чуть ниже, или скачать еще на сотнях подобных сайтов, необходимо отредактировать.
Для начала нужно поменять в шаблоне скрипта некоторые значения.
to
— меняем на почтовый адрес куда будет отправлено почтовое сообщение.
subject
— тема письма
message
— само сообщение, или тело письма.
Пример моего скрипта:
Можно конечно немного расширить функционал и сделать так, чтобы скрипт выдавал сообщение об отправки почты. Хоть на самом деле отправку производит именно SMTP-сервер, а скрипт лишь формирует сообщение.
Для примера можно написать так:
Все подставленные значения должны быть в кавычках, иначе скрипт выдаст ошибку. После этого можно сохранить скрипт в папку локального сервера.
Например: domains/send/index.php
и приступать к настройке отправки почты через SMTP opensrerver.
Почта будет приходить на любой адрес, который будет указан в скрипте вместо значения ‘to’
, но обрабатывать и отправлять эту почту будет именно тот SMTP, который будет указан в настройках openserver.
- Запускаем сервер
- Открываем модуль openserver с настройками в меню «почта»
- Заполняем все поля как показано на картинке, при этом, имя пользователя, e-mail отправителя и пароль подставляем от реального почтового ящика на яндексе.
Сохраняем настройки и после того, как сервер будет перезапущен, можно обратиться к самому скрипту. Из папки «Мои сайты», открыть папку «send» в которой и находится сохраненный ранее скрипт index.php.
Как только произойдет обращение к данному скрипту, в новом окне браузера появится информация о том, что скрипт отработал.
После этого стоит проверить свой почтовый ящик, адрес которого был указан в скрипте, пришло ли письмо.
Если его нет, значит что-то настроено не правильно, либо письмо попало в папку спам.
Все остальные настройки выглядят аналогично, но на всякий случай дополнительная информация не помешает.
Для того, чтобы настроить отправку почты через SMTP mail ru, необходимо просто заменить параметры яндекса на параметры mail ru.
А чтобы не перестраивать каждый раз локальные сервер, лучше всего настроить разные профили openserver. Как это сделать показано в видеоуроке .
В этом случае достаточно будет просто загрузить профиль и все настройки, которые были указаны для данного профиля будут доступны после перезапуска сервера. Очень удобная штука и работает очень просто.
Для каждого профиля (совсем не важно как он будет называться), должны быть сделаны свои настройки, если конечно планируется использование разных по своим параметрам скриптов, cms-систем и приложений.
Если нет, то можно обойтись и настройками по умолчанию.
Что касается SMTP mail ru, то здесь все эдентично.
Меняются данные яндекса на данные mail ru
Oтправка почты через smtp google
Для того, чтобы настроить отправку почты через SMTP гугла, стоит чуть постараться.
Во-первых, создание самого профиля в гугле сложнее чем в других системах яндекса и mail ru
Во-вторых, система просто так не пропустит письмо, даже если указать свои данные для входа. Для начала она пришлет письмо в котором и будет вся необходимая информация о дальнейших инструкциях.
В остальном же для гугла настраивается точно так же. Меняются только все данные .
Для настройки отправки почты через другие SMTP, все данные будут примерно одинаковы.
Если у вас все получилось и письма дошли до указанного адресата, значит все сделано правильно. Будет здорово если вы поделитесь своими наработками в комментариях.