Протокол SMTP
Simple Mail Transfer Protocol был разработан для обмена почтовыми сообщениями
в сети Internet. SMTP не зависит от транспортной среды и может использоваться
для доставки почты в сетях с протоколами, отличными от TCP/IP и Х.25.
Достигается это за счет концепции IPCE (InterProcess Communication Environment).
IPCE позволяет взаимодействовать процессам, поддерживающим SMTP в интерактивном
режиме, а не в режиме «STOP-GO».
Модель протокола
Взаимодействие в рамках SMTP строится по принципу двусторонней связи,
которая устанавливается между отправителем и получателем почтового сообщения.
При этом отправитель инициирует соединение и посылает запросы на обслуживание,
а получатель на эти запросы отвечает. Фактически, отправитель выступает
в роли клиента, а получатель — сервера.
Канал связи устанавливается непосредственно между отправителем и получателем
сообщения. При таком взаимодействии почта достигает абонента в течение
нескольких секунд после отправки.
Дисциплины работы и команды протокола
Обмен сообщениями и инструкциями в SMTP ведется в ASCII-кодах. В протоколе
определено несколько видов взаимодействия между отправителем почтового
сообщения и его получателем, которые здесь называются дисциплинами.
Наиболее распространенной дисциплиной является отправка почтового сообщения,
которая начинается по команде MAIL, идентифицирующей отправителя:
MAIL FROM: paul@quest.polyn.kiae.su
Следующей командой определяется адрес получателя:
RCPT ТО: paul@apollo.polyn.kiae.su
После того, как определен отправитель и получатель почтового сообщения,
можно отправлять последнее:
DATA
Команда DATA вводится без параметров и идентифицирует
начало ввода почтового сообщения. Сообщение вводится до тех пор, пока
не будет введена строка с точкой в первой позиции. Согласно стандарту
почтового сообщения RFC822 отправитель передает заголовок и тело сообщения,
которые разделены пустой строкой. Сам протокол SMTP не накладывает каких-либо
ограничений на информацию, которая заключена между командой DATA и «.»
в первой позиции последней строки. Приведем пример обмена сообщениями
при дисциплине отправки почты:
S: MAIL FROM: <paul@quest.polyn.kiae.su>
R: 250 Ok
S: RCPT TO: <dobr@kiae.su>
R: 250 Ok
S: DATA
R: 354 Start mail input; end with <CRLF>.<CRLF>
S: Это текст почтового сообщения
S: .
R: 250
Другой дисциплиной, определенной в протоколе SMTP является перенаправление
почтового сообщения (forwarding). Если получатель не найден, но известно
его местоположение, то сервер может выдать сообщение:
R: 251 User not local;
will forward to <user@domain.domain>
Если сервер может сделать только
предположение о дальнейшей рассылке, то ответ будет несколько иным:
R: 551 User not local;
please try <user@host.domain>
Верификация и расширение адресов составляют дисциплину верификации.
В ней используются команды VRFY и EXPN.
По команде VRFY сервер подтверждает наличие
или отсутствие указанного пользователя:
S: VRFY paul
R: 250-Paul Khramtsov<paul@quest. polyn. kiae. su>
Используя команду EXPN можно получить
список местных пользователей:
S: EXPN Example-People
R: 250-Paul Khramtsov<paul@quest.polyn.kiae.su>
R: 250-Vladimir Drach- Gorkunov<vovka@quest.polyn.kiae.su>
В список дисциплин, разрешенных протоколом SMTP входит кроме отправки
почты еще и прямая рассылка сообщений. В этом случае сообщение будет отправляться
не в почтовый ящик, а непосредственно на терминал пользователя, если пользователь
в данный момент находится за своим терминалом. Прямая рассылка осуществляется
по команде SEND, которая имеет такой же синтаксис,
как и команда MAIL. Кроме SEND прямую рассылку
осуществляют SGML (Send or Mail) и SAML
(Send and Mail). Назначение этих команд легко понять из их названия.
Для инициализации канала обмена почтой и его закрытия используются команды
HELO и QUIT соответственно.
Первой командой сеанса должна быть команда HELO.
Протокол допускает рассылку почтовых сообщений в режиме оповещения. Для
этой цели отправитель в адресе получателя может указать несколько пользователей
или групповой адрес. Обычно, программное обеспечение SMTP выбирает эту
информацию из заголовка почтового сообщения и на ее основе формирует параметры
команд протокола.
Если сообщение по какой-либо причине не может быть разослано, то получатель
формирует сообщение о неразосланном сообщении:
S: MAIL FROM:<>
R: 250 Ok
S: RCPT TO: <@host.domain:JOE@host.domain>
R: 250 Ok
S: DATA
R: 354 send the mail data, end with .
S: Date 23 Oct 95 11:23:30
S: From: SMTP@remote.domain
S: To: <JOE@host.domain>
S:
S: Undelivered message". Your message lost. 550 No such user.
S: .
При использовании доменных имен следует использовать канонические имена,
т.к. некоторые системы не могут определить синоним по базе данных named.
Кроме выше перечисленных дисциплин протокол позволяет отправителю и получателю
меняться ролями друг с другом. Происходит это по команде TURN.
Для отладки или проверки соединения по SMTP можно использовать telnet.
Для этого вслед за адресом машины следует ввести номер порта:
/users/local>telnet
apollo.polyn.kiae.su 25
25 порт используется в Internet для обмена сообщениями по протоколу
SMTP. В интерактивном режиме пользователь сам изображает клиента SMTP
и может посмотреть реакцию удаленной машины на его действия.
---
---
---
|