Что такое код imap_body

Содержание
Илон Маск рекомендует:  Что такое код cpdf_fill_stroke

Что такое код imap_body

(PHP 3, PHP 4, PHP 5)

imap_body — читает тело сообщения.

Описание

string imap_body (int imap_stream, int msg_number [, int flags])

imap_body() возвращает тело сообщения, пронумерованное как msg_number в текущем mailbox. Необязательные flags это битовая маска с одним или более из следующих значений:


FT_UID — msgno это UID

FT_PEEK — не устанавливать флаг \Seen, если ещё не установлен (?)

FT_INTERNAL — return-строка во внутреннем формате, не канонизирует в CRLF.

imap_body() возвратит только дословную копию тела сообщения. Для извлечения отдельных частей многочастного MIME-кодированного сообщения вы должны использовать imap_fetchstructure() для анализа его структуры и imap_fetchbody() — для извлечения копии одного компонента тела.

imap_body

imap_body — читает тело сообщения.

Описание

string imap_body (int imap_stream, int msg_number [, int flags])

imap_body() возвращает тело сообщения, пронумерованное как msg_number в текущем mailbox. Необязательные flags это битовая маска с одним или более из следующих значений:

FT_UID — msgno это UID

FT_PEEK — не устанавливать флаг \Seen, если ещё не установлен (?)

FT_INTERNAL — return-строка во внутреннем формате, не канонизирует в CRLF.

imap_body() возвратит только дословную копию тела сообщения. Для извлечения отдельных частей многочастного MIME-кодированного сообщения вы должны использовать imap_fetchstructure() для анализа его структуры и imap_fetchbody() — для извлечения копии одного компонента тела.

Что такое IMAP и POP?

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

IMAP и POP — это два метода доступа к электронной почте. Рекомендуется использовать IMAP, если вам требуется проверять почту с нескольких разных устройств (например, телефона, ноутбука и планшета).

IMAP позволяет получать доступ к электронной почте везде, где вы находитесь, с любого устройства. При чтении сообщения электронной почты с помощью IMAP вы не скачиваете его и не сохраняете на компьютере; Вместо этого вы читаете его из службы электронной почты. В результате вы можете проверять электронную почту с различных устройств в любом месте мира: на телефоне, компьютере, компьютере друга.

IMAP скачивает сообщение, только когда вы его щелкаете, и вложения не скачиваются автоматически. Так вы сможете проверять сообщения гораздо быстрее, чем с помощью POP.

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

Отправленная почта хранится локально на компьютере с Windows или Mac OS, а не на почтовом сервере.

Многие поставщики услуг Интернета предоставляют учетные записи электронной почты, которые используют POP.

Учетные записи веб-почты или почтовые приложения

Gmail, Outlook.com, Hotmail.com и iCloud — это веб-почта. Вход в учетную запись веб-почты выполняется в Интернете.

Если у вас есть компьютер с Windows или Mac OS, вы, вероятно, использовали программу, например Outlook, Apple Mail или Thunderbird, для управления электронной почтой. Outlook, Apple Mail и Thunderbird — это приложениядля работы с электронной почтой: программы, устанавливаемые на компьютере для управления электронной почтой. Они взаимодействуют с помощью службы электронной почты, например Gmail или Outlook.com, для получения и отправки электронной почты.

В почтовое приложение вы можете добавить любую учетную запись электронной почты, чтобы управлять ею оттуда. Например, вы можете добавить в приложение Outlook или Apple Mail учетные записи веб-почты (Gmail, Outlook.com, Hotmail.com, AOL и Yahoo) и почтовые учетные записи, предоставленные вашей организацией.

Добавление учетных записей веб-почты в почтовые приложения, такие как Outlook, Apple Mail, Thunderbird

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

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

Сервер входящей почты (IMAP): IMAP. _лт_ имя службы>. com

Сервер входящей почты (POP): pop. имя службы>.com

Сервер исходящей почты (SMTP): smtp. имя службы>.com

imap_body — Read the message body

(PHP 4, PHP 5, PHP 7)

imap_body — Read the message body

Описание

imap_body() returns the body of the message, numbered msg_number in the current mailbox.

imap_body() will only return a verbatim copy of the message body. To extract single parts of a multipart MIME-encoded message you have to use imap_fetchstructure() to analyze its structure and imap_fetchbody() to extract a copy of a single body component.

Список параметров

Поток IMAP, полученный из imap_open() .

The message number

The optional options are a bit mask with one or more of the following:

  • FT_UID — The msg_number is a UID
  • FT_PEEK — Do not set the \Seen flag if not already set
  • FT_INTERNAL — The return string is in internal format, will not canonicalize to CRLF.

Возвращаемые значения

Returns the body of the specified message, as a string.

4.4.14.3 Протокол Интернет для работы с сообщениями IMAP

Семенов Ю.А. (ИТЭФ-МФТИ)
Yu. Semenov (ITEP-MIPT)

Протокол IMAP 4.1 (INTERNET MESSAGE ACCESS PROTOCOL — VERSION 4rev1, V.Crispin, RFC-2060, December 1996) базируется на транспортном протоколе TCP и использует порт 143. Безопасная версия протокола IMAP использует порт 993. Протокол IMAP представляет собой альтернативу POP-3. Также как и последний он работает только с сообщениями и не требует каких-либо пакетов со специальными заголовками.

В отличие от POP3 IMAP хранит почтовые сообщения у себя “вечно” (пока клиент сам не пожелает их стереть).

1. Команды и отклики

Соединение IMAP 4.1 подразумевает установление связи между клиентом и сервером. Клиент посылает серверу команды, сервер клиенту данные и уведомления о статусе выполнения запроса. Все сообщения, как клиента, так и сервера имеют форму строк, которые завершаются последовательностью CRLF. Получатель (клиент или сервер) воспринимает такую строку или последовательность октетов известной длины, за которой следует строка.

1.1 Протокольный отправитель клиента и протокольный получатель сервера

Любая процедура начинается с команды клиента. Любая команда клиента начинается с префикса-идентификатора (обычно короткая буквенно-цифровая строка, например A0001, A0002 и т.д.), называемого меткой (tag). Для каждой команды клиент генерирует свою метку. Имеется два случая, когда строка, посланная клиентом, не представляет собой законченную команду. В первом — аргумент команды снабжается кодом, определяющим число октетов в строке (см. описание литеральных строк в разделе “Форматы данных”). Во втором — аргументы команды требуют отклика со стороны сервера (см. описание команды authenticate). В обоих вариантах сервер посылает запрос продолжения команды, если он готов. Такой отклик сервера начинается с символа «+».

Замечание: Если, вместо этого, сервер детектирует ошибку в команде, посылается отклик завершения bad с меткой, требующей игнорирования команды и предотвращения посылки клиентом каких-либо еще запросов.

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

Протокольный приемник IMAP 4.1 сервера читает строку команды, пришедшей от клиента, осуществляет ее разбор, выделяет ее параметры и передает серверу данные. По завершении команды сервер посылает отклик.

1.2 Протокольный отправитель сервера и протокольный получатель клиента

Данные, передаваемые сервером клиенту, а также статусные отклики, которые не указывают на завершение выполнения команды, имеют префикс «*» и называются непомеченными откликами.

Данные сервера могут быть посланы в ответ на команду клиента или отправлены сервером по своей инициативе. Формат данных не зависит от причины посылки.

Отклик указывает на успешное выполнение операции или на ее неудачу. Отклик использует ту же метку, что и команда клиента, запустившая процедуру. Таким образом, если осуществляется более чем одна команда, метка сервера указывает на команду, вызвавшую данный отклик. Имеется три вида отклика завершения сервера: ok (указывает на успешное выполнение), no (отмечает неуспех) или bad (указывает на протокольную ошибку, например, не узнана команда или зафиксирована синтаксическая ошибка).

Протокольный приемник клиента IMAP 4.1 читает строку отклика от сервера. Он должен предпринять действия, в соответствии с первым символом метки «*» или «+».

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

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

Доступ к сообщениям в IMAP 4.1 осуществляется с помощью уникального идентификатора или порядкового номера сообщения.

1.3 Атрибут сообщения UID

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

В отличие от порядкового номера сообщения, уникальные идентификаторы не образуют упорядоченной последовательности, но они работают и за пределами текущей сессии. Это позволяет осуществлять ссылки на сообщение в случае обрыва сессии [IMAP-DISC].

UID ассоциируется с почтовым ящиком и посылается в виде кода uidvalidity отклика (ok) на фазе выбора почтового ящика. Если UID из предыдущей сессии по какой-то причине не может быть использован, UID должен быть инкрементирован.

UID для данного почтового ящика должен всегда изменяться монотонно. Если порядок записей изменен вне рамок IMAP, необходимо перегенерировать UID для данного почтового ящика, так как порядок старых значений UID в этом случае уже не будет монотонным.

Еще одной причиной не сохранения UID может служить стирание старого и создание нового почтового ящика с тем же именем. Так как имя почтового ящика не изменилось, клиент может не знать об этом и пытаться использовать старые UID. Хорошим значением UID можно считать 32-битное представление даты и времени создания почтового ящика. Вполне приемлемо и значение 1, если имеется гарантия, что это значение никогда не будет использовано повторно, даже в случае стирания и создания нового почтового ящика с тем же именем.

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

Атрибут порядкового номера сообщения

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

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

Номера сообщений могут использоваться при вычислениях, касающихся указателей. Например, если сообщение 287 в почтовом ящике, содержащем 523 сообщения, имеет UID 12345, имеется 286 сообщений, имеющих меньшее значение UID и 236 сообщений с большими UID.

1.4 Атрибут флагов сообщения

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

Системным флагом является флаг, чье имя определено в данной спецификации. Все системные флаги начинаются с символа «\». Некоторые системные флаги (\deleted и \seen) имеют специальную семантику, заданную вне рамок данного документа. В настоящее время определены следующие системные флаги:

\seen Сообщение прочитано
\answered На сообщение послан ответ
\flagged Сообщение «помечено» как срочное, требующее особого внимания
\deleted Сообщение помечено как стертое для последующего удаления посредством expunge
\draft Сообщения не является законченным (помечено, как проект).
\recent Сообщение только что положено в почтовый ящик. Эта сессия является первой, где фигурирует данное сообщение; для последующих сессий это сообщение не будет иметь флага \recent. Флаг не может быть изменен клиентом.

Если невозможно определить, является ли эта сессия первой для данного сообщения, его следует считать относящимся к текущей сессии. Ключевое слово определяется реализацией сервера. Ключевые слова не начинаются с символа «\». Серверы могут позволять клиенту создавать новые ключевые слова в почтовом ящике. Постоянные флаги клиент может устанавливать для данного сообщения или удалять на постоянной основе; таким образом, последующая сессия может воспользоваться новыми значениями флагов.

Системный флаг \recent имеет статус флага сессии. Флаг \recent не может использоваться в качестве аргумента команды store, и по этой причине не может быть изменен вообще.

Внутренняя дата и время сообщения на сервере. Это не та дата и время, которые указаны в заголовке [RFC-822], а время и дата получения сообщения. В случае доставки сообщения посредством протокола [SMTP], это должна быть дата и время доставки конечному адресату. В случае сообщений, доставленных командой IMAP 4.1 copy, это должны быть внутренняя дата и время отправителя сообщения. В случае доставки сообщения командой IMAP 4.1 append, это должна быть дата и время, заданные в описании команды append.

Атрибут размера сообщения определяет число октетов в сообщении (рассмотрен в документе [RFC-822]). Атрибут структуры конверта сообщения соответствует требованиям документа [RFC-822]. Атрибут структуры тела сообщения несет в себе информацию о структуре сообщения в соответствии с регламентациями [MIME-IMB]. Кроме доставки текстового сообщения, как это описано в RFC-822, IMAP 4.1 позволяет осуществлять передачу части текста. Можно отдельно доставить заголовок и тело сообщения или даже часть тела сообщения.

2. Состояние и диаграмма исполнения

Сервер IMAP 4.1 находится в одном из четырех состояний. Большинство команд допустимо только во вполне определенных состояниях. Если клиент пытается реализовать команду в неправильном состоянии, это рассматривается как протокольная ошибка. В этом случае сервер откликнется командой bad или no в зависимости от реализации конкретной программы.

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

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

В состояние выбора система попадает, когда успешно осуществлен выбор почтового ящика. В состояние выхода система попадает при прерывании соединения в результате запроса клиента или вследствие независимого решения сервера.

Рис. 4.4.14.2.1. Схема состояний для протокола IMAP

(1) Cоединение без предварительной аутентификации (отклик OK)
(2) Cоединение с предварительной аутентификацией (отклик PREAUTH)
(3) Соединение отвергнуто (отклик BYE)
(4) Успешное завершение команды LOGIN или AUTHENTICATE
(5) Успешное завершение команды SELECT или EXAMINE
(6) Выполнение команды CLOSE, или неудачная команда SELECT или EXAMINE
(7) Выполнение команды LOGOUT, закрытие сервера, или прерывание соединения

3. Формат данных

IMAP 4.1 использует текстовые команды и отклики. Данные в IMAP 4.1 могут иметь одну из следующих форм: атом, число, строка, список, заключенный в скобки или NIL.

Атом состоит из одного или более неспециализированных символов.

Число состоит из одной или более цифр и характеризует некоторое числовое значение.

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

Литерал представляет собой нуль или более октетов (включая CR и LF). Литерал начинается с октета, где хранится число символов. Этот октет заключается в фигурные скобки, за которыми следует последовательность CRLF. В случае передачи литералов от сервера к клиенту за CRLF следуют непосредственно данные. При передаче литералов от клиента серверу клиент должен подождать прихода команды продолжения, прежде чем начать пересылку данных.

Строка в кавычках представляет собой последовательность из нуля или более 7-битовых символов за исключением CR и LF, начинающуюся и завершающуюся двойной кавычкой ( ). Пустая строка представляется как «» или как литерал <0>, за которым следует последовательность CRLF.

Замечание: Даже если число октетов равно нулю, клиент, передающий литерал должен подождать прихода команды продолжения.

3.1. 8-битовые и двоичные строки

8-битовая текстовая и двоичная почта поддерживается посредством шифрования [MIME-IMB]. Реализации IMAP 4.1 могут передавать 8-битные или многооктетные символы в литералах, но должны это делать, только когда определен [CHARSET]. Если даже определена кодировка BINARY, незакодированные двоичные строки не могут быть разрешены. «Двоичная строка» — это любая строка из NUL символов. Реализации программ должны перекодировать двоичные данные в текстовую форму, такую как BASE64, прежде чем их пересылать. Строка с большим числом символов CTL может рассматриваться как двоичная.

3.2. Список в скобках

Структуры данных представляются в виде списков, помещенных в скобки, элементы списка разделяются пробелами. Такой список может включать в себя другие “списки в скобках”. Пустой список выглядит как () — “список в скобках” с нулевым числом членов.

3.3. NIL

Специальный атом «NIL» представляет собой указание на отсутствие каких-то определенных данных типа строка или “список в скобках”. Его следует отличать от пустой строки «» или пустого “списка в скобках” ().

4. Операционные соображения
4.1. Присвоение имени почтовому ящику

Интерпретация имен почтовых ящиков является независимой от конкретной программной реализации. Однако имя почтового ящика INBOX является специальным именем, зарезервированным для «первичного почтового ящика данного пользователя на данном сервере» (значение не зависит от использования строчных или прописных букв). Почтовые ящики могут образовывать иерархическую структуру. Если желательно экспортировать иерархию имен почтовых ящиков, имена почтовых ящиков должны быть упорядочены по буквам слева направо.

4.2. Соглашение о пространстве имен почтовых ящиков

В соответствии с соглашением первый иерархический элемент любого имени почтового ящика, который начинается с символа «#» указывает на “пространство имен” остальной части имени. Например, реализации, которые предлагают доступ к группам новостей USENET могут использовать пространство имен «#news», для того чтобы отделить пространство имен групп новостей от имен других почтовых ящиков. Таким образом, группа новостей comp.mail.misc будет иметь имя почтового ящика «#news.comp.mail.misc», а имя «comp.mail.misc» может относиться к другому объекту (напр., к почтовому ящику пользователя).

4.3. Международное соглашение об именах почтовых ящиков

Согласно договоренности имена международных почтовых ящиков специфицированы в соответствии модифицированной версией кодировки UTF-7, описанной в [UTF-7]. Целью этих модификаций было устранение следующих проблем, связанных с UTF-7:

  1. UTF-7 использует символ «+» для смещения; это вызывает конфликт с обычным применением «+» в именах почтовых ящиков, в частности в именах групп новостей USENET.
  2. Кодировка UTF-7 базируется на BASE64, где используется символ «/», что вступает в конфликт с применением «/» в качестве популярного иерархического разделителя.
  3. UTF-7 запрещает использование «\»; что противоречит применению «\» в качестве популярного разделителя.
  4. UTF-7 запрещает использование «

«, это вступает в конфликт с тем, что некоторые серверы рассматривают этот символ, как указатель на базовый каталог (home).

  • UTF-7 допускает разнообразные формы представления одних и тех же строк, в частности, печатные символы US-ASCII могут использоваться в закодированной форме.
  • В модифицированном UTF-7, печатные символы US-ASCII за исключением «&» представляются в исходном виде; то есть, символами со значениями октетов 0x20-0x25 и 0x27-0x7e. Символ «&» (0x26) представляется в виде двух октетной последовательности «&-«. Все другие символы (значения октетов 0x00-0x1f, 0x7f-0xff, и все уникодные 16-битовые октеты) представляются в модифицированной кодировке BASE64, с дополнительными видоизменениями из [UTF-7]. Модифицированная BASE64 не должна использоваться для представления любых печатных символов US-ASCII, которые должны представлять самих себя.

    Символ «&» используется для перехода к модифицированной кодировке BASE64 а «-» для возврата назад к US-ASCII. Все имена начинаются с US-ASCII, и должны завершаться US-ASCII (то есть, имя, которое заканчивается уникодным 16-битовым октетом, должно быть завершено символом «-«). Примером может служить имя почтового ящика, в котором смешаны фрагменты текста на английском, японском и китайском языках:

    4.4. Размер почтового ящика и актуализации состояния сообщений

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

    4.5. Отклик в случае, когда не исполняется никакой команды

    Реализациям сервера разрешается посылать непомеченные отклики (за исключением EXPUNGE), если в это время не выполняется ни одной команды. Реализации, которые посылают такие отклики, должны учитывать соображения управления трафиком. В частности, они должны либо (1) проверить, что размер данных не превосходит транспортные возможности, или (2) использовать неблокирующую запись.

    4.6. Таймер автоматического отключения (Autologout)

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

    4.7. Одновременное исполнение нескольких команд

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

    Исключение может составлять случаи, когда результат выполнения одной команды зависит от выполнения других команд. Клиенты не должны посылать несколько команд, не дожидаясь результата, если возможна неопределенность из-за их взаимозависимости. Если сервер детектирует возможную неопределенность, он должен исполнить их последовательно в порядке их получения от клиента.

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

    Неочевидные неопределенности возникают с командами, которые допускают немаркированный отклик EXPUNGE (команды отличные от FETCH, STORE и SEARCH), так как немаркированный отклик EXPUNGE может нарушить корректность порядковых номеров сообщений для последующих команд. Это не представляет проблем для команд FETCH, STORE или SEARCH, так как серверам запрещено посылать отклики EXPUNGE, когда исполняется одна их этих команд. Следовательно, если клиент посылает любую команду, отличную от FETCH, STORE или SEARCH, он должен ждать отклика, прежде чем посылать команду, содержащую номер сообщения. Например, следующая последовательность команд (без ожидания) является некорректной:

    FETCH + NOOP + STORE
    STORE + COPY + FETCH
    COPY + COPY
    CHECK + FETCH

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

    FETCH + STORE + SEARCH + CHECK
    STORE + COPY + EXPUNGE

    5. Команды клиента

    Ниже описаны команды IMAP 4.1. Команды рассматриваются с учетом состояния, в котором они допустимы.

    5.1. Команды клиента — любое состояние

    Следующие команды могут использоваться в любом состоянии: CAPABILITY, NOOP и LOGOUT.

    5.1.1. Команда CAPABILITY

    Аргументы: отсутствуют.
    Отклики: Необходим немаркированный отклик: CAPABILITY.
    Результат: OK — успешное завершение команды;
    BAD — команда неизвестна или неверный аргумент

    Команда CAPABILITY запрашивает перечень возможностей, поддерживаемых сервером. Сервер должен послать один немаркированный отклик CAPABILITY с «IMAP 4.1» в списке возможностей, прежде чем отправлять маркированный отклик OK. Этот список не зависит от состояния соединения или пользователя. Следовательно, нет необходимости направлять команду CAPABILITY более одного раза на соединение. Название возможности, которая начинается с «AUTH=» указывает, что сервер поддерживает определенный механизм аутентификации. Все такие имена по определению являются частью данной спецификации. Например, аутентификационные возможности для экспериментального аутентификатора «blurdybloop» могут быть описаны как «AUTH=XBLURDYBLOOP», а не «XAUTH=BLURDYBLOOP» или «XAUTH=XBLURDYBLOOP».

    Другие имена возможностей относятся к расширениям, новым версиям или коррекциям данной спецификации.

    Пример: C: abcd CAPABILITY
    S: * CAPABILITY IMAP 4.1 AUTH=KERBEROS_V4
    S: abcd OK CAPABILITY completed

    5.1.2. Команда NOOP

    Аргументы: отсутствуют.
    Отклики: никакого специального отклика на эту команду не требуется.
    Результат: OK — команда успешно завершена;
    BAD — команда неизвестна или неверен аргумент;
    Команда NOOP ничего не делает и всегда успешно завершается.

    Так как любая команда может прислать немаркированные данные об изменении состояния, команда NOOP может использоваться, как периодический запрос нового сообщения или информации об изменении статуса в периоды неактивности. Команда NOOP может также использоваться для сброса таймера прерывания сессии сервером из-за отсутствия активности.

    Пример: C: a002 NOOP
    S: a002 OK NOOP completed
    . . .
    C: a047 NOOP
    S: * 22 EXPUNGE
    S: * 23 EXISTS
    S: * 3 RECENT
    S: * 14 FETCH (FLAGS (\Seen \Deleted))
    S: a047 OK NOOP completed

    5.1.3. Команда LOGOUT

    Аргументы: отсутствуют.
    Отклики: необходим немаркированный отклик BYE.
    Результат: OK — прерывание сессии завершено;
    BAD — неизвестная команда или неверный аргумент.

    Команда LOGOUT информирует сервер о том, что клиент прерывает соединение. Сервер должен послать немаркированный отклик BYE, прежде чем отсылать маркированный отклик OK, после чего завершить разрыв соединения.

    Пример: C: A023 LOGOUT
    S: * BYE IMAP 4.1 Server logging out
    S: A023 OK LOGOUT completed
    (Сервер и клиент разорвали соединение)

    5.2. Команды клиента — в состоянии без аутентификации

    В состоянии без аутентификации, команды AUTHENTICATE или LOGIN организуют аутентификацию и переводят систему в состояние с аутентификацией. Об аутентификации в IMAP можно прочесть в документе RFC-1731. Команда AUTHENTICATE предоставляет общий механизм для целого ряда методов аутентификации, среди которых команда LOGIN используется для традиционного ввода имени и пароля в текстовом виде.

    Различные реализации сервера могут позволять доступ без аутентификации к некоторым почтовым ящикам. По договоренности в этом случае команда LOGIN предполагает ввод имени «anonymous». Ввод пароля всегда обязателен. Требования на пароль определяются конкретной версией программной реализации.

    По завершении аутентификации невозможно вернуться непосредственно в состояние “без аутентификации”. В дополнение к универсальным командам (CAPABILITY, NOOP и LOGOUT), в состоянии “без аутентификации” возможны команды: AUTHENTICATE и LOGIN.

    5.2.1. Команда AUTHENTICATE

    Аргументы: имя механизма аутентификации.
    Отклики: может быть запрошена дополнительная информация.

    Результат OK Аутентификация завершена, осуществлен переход в состояние «аутентификация выполнена»;
    NO Ошибка аутентификации: неподдерживаемый механизм аутентификации, параметры аутентификации отвергнуты;
    BAD Неизвестная команда или неверный аргумент, механизм аутентификации прерван.

    Команда AUTHENTICATE указывает серверу на механизм аутентификации, как это описано в [IMAP-AUTH]. Если сервер поддерживает запрошенный механизм аутентификации, он выполняет обмен согласно аутентификационному протоколу и идентифицирует клиента. Он может также согласовать опционный механизм защиты для последующих протоколов взаимодействия. Если запрошенный механизм аутентификации не поддерживается, сервер должен отвергнуть команду AUTHENTICATE путем посылки маркированного отклика NO.

    Протокол аутентификационного обмена состоит из последовательности запросов сервера и соответствующих ответов клиента. Запрос сервера состоит из отклика-запроса продолжения с символом «+», за которым следует строка кодов BASE64. Ответ клиента состоит из строки, содержащей коды BASE64. Если клиент хочет аннулировать аутентификационный обмен, он выдает строку, содержащую только «*». Если сервер получает такой ответ, он должен отклонить команду AUTHENTICATE, послав маркированный отклик BAD.

    Механизм защиты обеспечивает целостность и конфиденциальность соединения. Если механизм защиты согласовыван, то в дальнейшем он используется для всех сообщений, проходящих через данное соединение. Механизм защиты начинает действовать сразу после ввода последовательности CRLF, которая завершает аутентификационный обмен для клиента, и прихода CRLF маркированного отклика OK сервера. Раз механизм защиты вступил в силу, поток октетов команд и откликов заносится в буферы шифрованного текста. Каждый буфер передается через соединение в виде потока октетов, который начинается с четырех октетов, содержащих длину последующих данных. Максимальный размер буфера для текста-шифра определяется выбранным механизмом защиты.

    Аутентификационные механизмы являются опционными. Механизмы защиты также опционны; аутентификационный механизм может реализоваться в отсутствии какого-либо механизма защиты. Если команда AUTHENTICATE не прошла и получен отклик NO, клиент может совершить повторную попытку, послав еще одну команду AUTHENTICATE, или может попытаться выполнить аутентификацию с помощью команды LOGIN. Другими словами, клиент может затребовать тип аутентификации в порядке понижения уровня предпочтения, команда LOGIN используется как последний вариант.

    Пример: S: * OK KerberosV4 IMAP4rev1 Server
    C: A001 AUTHENTICATE KERBEROS_V4
    S: + AmFYig==
    C: BAcAQU5EUkVXLkNNVS5FRFUAOCAsho84kLN3/IJmrMG+25a4DT
    +nZImJjnTNHJUtxAA+o0KPKfHEcAFs9a3CL5Oebe/ydHJUwYFd
    WwuQ1MWiy6IesKvjL5rL9WjXUb9MwT9bpObYLGOKi1Qh
    S: + or//EoAADZI=
    C: DiAF5A4gA+oOIALuBkAAmw==
    S: A001 OK Kerberos V4 authentication successful

    5.2.2. Команда LOGIN

    Аргументы: имя пользователя, пароль.
    Отклики: команда не требует какого-либо специального отклика.
    Результат: OK — login завершено, система в состоянии с аутентификацией;
    NO — login не прошла: имя пользователя или пароль отвергнуты;
    BAD — команда неизвестна или неверный аргумент.

    Команда LOGIN идентифицирует клиента серверу и передает пароль пользователя открытым текстом.

    Пример: C: a001 LOGIN SMITH S ESAME
    S: a001 OK LOGIN completed

    5.3. Команды клиента в состоянии «аутентификация осуществлена»

    В состоянии «аутентификация осуществлена» разрешены команды манипуляции почтовыми ящиками, как объектами-атомами. Команды SELECT и EXAMINE реализует выбор почтового ящика и переход в состояние «выбрано» .

    В добавление к стандартным командам (CAPABILITY, NOOP и LOGOUT), в состоянии «аутентификация осуществлена» допустимы следующие команды: SELECT, EXAMINE, CREATE, DELETE, RENAME, SUBSCRIBE, UNSUBSCRIBE, LIST, LSUB, STATUS и APPEND.

    5.3.1. Команда SELECT

    Аргументы: имя почтового ящика.
    Отклики: необходимы немаркированные отклики: FLAGS, EXISTS, RECENT;
    опционны немаркированные отклики OK: UNSEEN, PERMANENTFLAGS.

    Результат: OK — процедура выбора закончена, система находится в состоянии «выбрано» ;
    NO — выбор неудачен: нет такого ящика, доступ к почтовому ящику невозможен;
    BAD — команда неизвестна или неверен аргумент.

    Команда SELECT осуществляет выбор почтового ящика, так чтобы обеспечить доступ к сообщениям, находящимся там. Прежде чем присылать клиенту OK, сервер должен послать клиенту следующие немаркированные данные:

    FLAGS — флаги, определенные для почтового ящика.
    EXISTS Число сообщений в почтовом ящике.
    RECENT Число сообщений с набором флагов \Recent.
    OK [UIDVALIDITY ] Уникальный идентификатор корректности.

    Сервер должен также послать «невидимый» код отклика внутри немаркированного сообщения OK, который представляет собой порядковый номер первого невидимого сообщения в почтовом ящике.

    Если клиент не может изменить состояние одного или нескольких флагов, перечисленных в немаркированном отклике FLAGS, сервер должен в немаркированном отклике OK послать код PERMANENTFLAGS, перечислив флаги, которые клиент может изменить.

    Единовременно для одного соединения может быть выбран только один почтовый ящик. Одновременный доступ к нескольким почтовым ящикам требует установления соответствующего числа соединений. Команда SELECT автоматически аннулирует выбор почтового ящика при повторной попытке его выбора. Следовательно, если почтовый ящик был выбран, а команда SELECT не прошла, предшествующий выбор ящика аннулирован. Если клиенту разрешено модифицировать почтовый ящик, сервер должен снабжать маркированный текст отклика OK префиксом «[READ-WRITE]».

    Если клиенту не позволено модифицировать почтовый ящик, но разрешен доступ для чтения, почтовый ящик выбирается в режиме «только для чтения» и сервер должен перед посылкой текста передать маркированный отклик OK в ответ на команду SELECT с кодом отклика «[READ-ONLY]». Доступ «только для чтения» тем не менее, отличается от команды EXAMINE, при нем некоторые почтовые ящики позволяют изменять постоянное состояние некоторых флагов пользователя. Сетевые новости из файла .newsrc являются примером того, как некоторые состояния могут изменяться для почтовых ящиков типа «только для чтения».

    Пример: C: A142 SELECT INBOX
    S: * 172 EXISTS
    S: * 1 RECENT
    S: * OK [UNSEEN 12] Message 12 is first unseen
    S: * OK [UIDVALIDITY 3857529045] UIDs valid
    S: * FLAGS (\Answered \Flag ged \Deleted \Seen \Draft)
    S: * OK [PERMANENTFLAGS (\Deleted \Seen \*)] Limited
    S: A142 OK [READ-WRITE] SELECT completed

    5.3.2. Команда EXAMINE

    Аргументы: имя почтового ящика.
    Отклики: необходимы немаркированные отклики: FLAGS, EXISTS, RECENT;
    опционны немаркированные отклики OK: UNSEEN, PERMANENTFLAGS.

    Результат: OK Осмотр закончен, система в состоянии «выбор сделан» ;
    NO Осмотр не прошел, система в состоянии «аутентификация выполнена» ; нет такого почтового ящика; доступ к почтовому ящику невозможен;
    BAD Команда неизвестна или неверен аргумент.

    Команда EXAMINE идентична команде SELECT и дает тот же результат, однако, выбранный почтовый ящик идентифицируется как «только для чтения». Никакие изменения постоянного состояния почтового ящика в этом случае не разрешены. Текст маркированного отклика OK на команду EXAMINE должен начинаться с кода отклика «[READ-ONLY]».

    Пример: C: A932 EXAMINE blurdybloop
    S: * 17 EXISTS
    S: * 2 RECENT
    S: * OK [UNSEEN 8] Message 8 is first unseen
    S: * OK [UIDVALIDITY 3857529045] UIDs valid
    S: * FLAGS (\Answered \Flagged \Deleted \Seen \Draft)
    S: * OK [PERMANENTFLAGS ()] No permanent flags permitted
    S: A932 OK [READ-ONLY] EXAMINE completed

    5.3.3. Команда CREATE

    Аргументы: имя почтового ящика.
    Отклики: на эту команду не посылается каких-либо откликов.

    Результат OK Команда выполнена;
    NO команда не выполнена: почтовый ящик с таким именем не может быть создан;
    BAD команда неизвестна или неверен аргумент.

    Команда CREATE создает почтовый ящик с заданным именем. Отклик OK присылается в случае, когда новый почтовый ящик с указанным именем создан. Попытка создания INBOX или почтового ящика с именем, существующего почтового ящика, является ошибкой . Любая ошибка при попытке создания почтового ящика вызовет маркированный отклик NO.

    Если имя почтового ящика имеет суффикс с символом сепаратора иерархии сервера (в соответствии с тем, что получено при выполнении команды LIST), то это является декларацией клиента о намерении создать почтовый ящик с именем в рамках указанной иерархии. Реализации сервера, которые не требуют этой декларации, должны ее игнорировать.

    Если символ-сепаратор иерархии сервера появляется где-либо еще в имени, сервер должен создать любые имена более высокого уровня иерархии, которые необходимы для успешного завершения выполнения команды CREATE. Другими словами, попытка создания «foo/bar/zap» на сервере, для которого символ «/» является иерархическим сепаратором, должна привести к созданию foo/ и foo/bar/, если они до этого не существовали.

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

    Пример: C: A003 CREATE owatagusiam/
    S: A003 OK CREATE completed
    C: A004 CREATE owatagusiam/blurdybloop
    S: A004 OK CREATE completed

    Замечание: интерпретация этого примера зависит от того, является ли символ «/» иерархическим сепаратором. Если «/» иерархический сепаратор, создается новый иерархический уровень с «owatagusiam» с новым членом иерархии этого уровня «blurdybloop». В противном случае создаются два почтовых ящика на одном и том же уровне иерархии.

    5.3.4. Команда DELETE

    Аргументы: имя почтового ящика.
    Отклики: команда не требует каких-либо откликов.
    Результат: OK — команда завершена;
    NO — ошибка при выполнении команды: не удается стереть ящик с этим именем;
    BAD — команда неизвестна или неверен аргумент.

    Команда DELETE навечно удаляет почтовый ящик с указанным именем. При этом присылается маркированный отклик OK только в том случае, когда ящик уничтожен. Ошибкой считается попытка стереть INBOX или ящик с несуществующим именем.

    Команда DELETE не должна удалять ящики с более низкой иерархией, чем текущая. Например, если почтовый ящик «foo» имеет иерархическую структуру «foo.bar» (предполагается, что «.» является иерархическим сепаратором), удаление «foo» не должно удалять «foo.bar». Считается ошибкой попытка удаления имени, которому соответствуют нижележащие иерархические уровни, имеющие атрибут \Noselect.

    Разрешено удалять имена, которым соответствуют нижележащие иерархические уровни, но не имеющие атрибута имени \Noselect. В этом случае все сообщения из этого почтового ящика также будут удалены, а имя получит атрибут \Noselect.

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

    Примеры: C: A682 LIST «» *
    S: * LIST () «/» blurdybloop
    S: * LIST (\Noselect) «/» foo
    S: * LIST () «/» foo/bar
    S: A682 OK LIST completed
    C: A683 DELETE blurdybloop
    S: A683 OK DELETE completed
    C: A684 DELETE foo
    S: A684 NO Name «foo» has inferior hierarchical names
    C: A685 DELETE foo/bar
    S: A685 OK DELETE Completed
    C: A686 LIST «» *
    S: * LIST (\Noselect) «/» foo
    S: A686 OK LIST completed
    C: A687 DELETE foo
    S: A687 OK DELETE Completed
    C: A82 LIST «» *
    S: * LIST () «.» blurdybloop
    S: * LIST () «.» foo
    S: * LIST () «.» foo.bar
    S: A82 OK LIST completed
    C: A83 DELETE blurdybloop
    S: A83 OK DELETE completed
    C: A84 DELETE foo
    S: A84 OK DELETE Completed
    C: A85 LIST «» *
    S: * LIST () «.» foo.bar
    S: A85 OK LIST completed
    C: A86 LIST «» %
    S: * LIST (\Noselect) «.» foo
    S: A86 OK LIST completed

    5.3.5. Команда RENAME

    Аргументы: имя существующего почтового ящика, имя нового почтового ящика.
    Отклики: эта команда не требует каких-либо специфических откликов.

    Результат: OK переименование успешно осуществилось;
    NO переименование не прошло: не удалось переименовать ящик с данным именем, не удалось присвоить новое имя;
    BAD команда неизвестна или неверен аргумент.

    Команда RENAME изменяет имя почтового ящика. Маркированный отклик OK присылается лишь в случае, когда почтовый ящик переименован. Считается ошибкой попытка переименовать не существующий почтовый ящик или присвоить ящику уже имеющееся имя. Любая ошибка при переименовании вызовет маркированный отклик NO.

    Если ящик содержит в себе иерархическую структуру, имена этой структуры не должны меняться. Например, переименование «foo» в «zap» переименует «foo/bar» (предполагая, что «/» является иерархическим разделителем) в «zap/bar».

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

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

    Примеры: C: A682 LIST «» *
    S: * LIST () «/» blurdybloop
    S: * LIST (\Noselect) «/» foo
    S: * LIST () «/» foo/bar
    S: A682 OK LIST completed
    C: A683 RENAME blurdybloop sarasoop
    S: A683 OK RENAME completed
    C: A684 RENAME foo zowie
    S: A684 OK RENAME Completed
    C: A685 LIST «» *
    S: * LIST () «/» sarasoop
    S: * LIST (\Noselect) «/» zowie
    S: * LIST () «/» zowie/bar
    S: A685 OK LIST completed
    C: Z432 LIST «» *
    S: * LIST () «.» INBOX
    S: * LIST () «.» INBOX.bar
    S: Z432 OK LIST completed
    C: Z433 RENAME INBOX old-mail
    S: Z433 OK RENAME completed
    C: Z434 LIST «» *
    S: * LIST () «.» INBOX
    S: * LIST () «.» INBOX.bar
    S: * LIST () «.» old-mail
    S: Z434 OK LIST completed

    5.3.6. Команда SUBSCRIBE

    Аргументы: имя почтового ящика.
    Отклики: эта команда не требует каких-либо специфических откликов.
    Результат: OK — процедура подписки завершена;
    NO — подписка не прошла: подписка для данного имени невозможна;
    BAD — команда неизвестна или неверен аргумент.

    Команда SUBSCRIBE добавляет специфицированное имя почтового ящика к списку «активных» или «подписных» ящиков сервера, как это реализуется командой LSUB. Эта команда присылает маркированный отклик OK только в случае успешного осуществления подписки.

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

    Замечание: это требование возникает потому, что некоторые серверы могут удалить почтовый ящик с известным именем, например, «system-alerts») после того как срок годности его содержимого истек с тем, чтобы создать его вновь при появлении новых сообщений.

    Пример: C: A002 SUBSCRIBE #news.comp.mail.mime
    S: A002 OK SUBSCRIBE completed

    5.3.7. Команда UNSUBSCRIBE

    Аргументы: имя почтового ящика.
    Отклики: эта команда не требует каких-либо специфических откликов.
    Результат: OK — ликвидация подписки прошла успешно;
    NO — ликвидация подписки не прошла: это невозможно для данного имени;
    BAD — команда неизвестна или неверен аргумент.

    Команда UNSUBSCRIBE удаляет специфицированный почтовый ящик из списка «активных» или «подписных» почтовых ящиков данного сервера, как это определяется командой LSUB. Эта команда возвращает маркированный отклик OK только в случае, если ликвидация подписки прошла успешно.

    Пример: C: A002 UNSUBSCRIBE #news.comp.mail.mime
    S: A002 OK UNSUBSCRIBE completed

    5.3.8. Команда LIST

    Аргументы: имя,
    имя почтового ящика может содержать символы подмены (wildcard).
    Отклики: немаркированные отклики LIST.

    Результат: OK команда list выполнена;
    NO команда не прошла: не возможно выполнение list для данного образца или имени;
    BAD команда неизвестна или неверен аргумент.

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

    Команда LIST должна возвращать данные быстро без существенных задержек. Например, она не должна тратить время на выяснение статуса (\Marked или \Unmarked) или на выполнение другой трудоемкой обработки, ведь если каждое имя требует одной секунды, то обработка списка из 1200 имен займет 20 минут.

    Аргумент, содержащий пустую строку образца имени («»), указывает, что имя почтового ящика интерпретируется также, как это делает команда SELECT. Присланные имена почтовых ящиков должны соответствовать полученному шаблону имени. Непустой аргумент является шаблоном имени почтового ящика или уровеня иерархии и указывает на контекст, в котором интерпретируется имя. Пустой аргумент имени («») представляет собой специальный запрос, требующий присылки иерархического разделителя и корневого имени. Значение, возвращаемое в качестве корневого имени, может быть нулем, если шаблону не соответствует никакая иерархия. Иерархический разделитель присылается во всех случаях. Это позволяет клиенту получить иерархический разделитель даже в случае, когда нет почтовых ящиков, соответствующих данному имени.

    Шаблон и имя почтового ящика интерпретируются по-разному в зависимости от реализации. В каноническом варианте анализ происходит слева направо.

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

    Ниже приведены некоторые примеры того, как могут интерпретироваться образцы и имена почтовых ящиков на серверах базирующихся на UNIX:

    smith/Mail/

    smith/Mail/foo.*

    smith/Mail/

    fred/Mail/*

    fred/Mail/*

    Шаблон Имя почтового ящика Интерпретация
    foo.*
    Archive/ % archive/%
    #news. comp.mail.* #news.comp.mail.*
    /usr/doc/foo /usr/doc/foo
    archive/

    Первые три примера демонстрируют интерпретацию в контексте аргумента шаблона. Заметьте, что «

    smith/Mail» не должно преобразоваться во что-то подобное «/u2/users/smith/Mail», иначе для клиента было бы невозможно определить, соответствовала ли интерпретация контексту шаблона.

    Символ «*» представляет собой подмену (wildcard), и соответствует нулю или более символов в данной позиции. Символ «%» подобен «*», но он не соответствует иерархическому разделителю. Если символ «%» является последним символом имени почтового ящика, то в отклике будут присланы и соответствующие уровни иерархии. Если эти уровни не являются почтовыми ящиками, которые можно выбрать, то их имена снабжаются атрибутом \Noselect. Реализациям сервера таким образом позволено спрятать некоторые почтовые ящики, имена которых могли бы быть раскрыты с использованием шаблонов с символами подмены (wildcard). Например, сервер на основе UNIX может ограничить интерпретацию «*» так, что начальный символ «/» будет приводить к несоответствию имени шаблону.

    Специальное имя INBOX включается в выдачу команды LIST, если INBOX поддерживается данным сервером для данного пользователя и, если строка «INBOX», напечатанная прописными буквами, соответствует интерпретированному шаблону.

    Пример: C: A101 LIST «» «»

    S: * LIST (\Noselect) «/» «»
    S: A101 OK LIST Completed
    C: A102 LIST #news.comp.mail.misc «»
    S: * LIST (\Noselect) «.» #news.
    S: A102 OK LIST Completed
    C: A103 LIST /usr/staff/jones «»
    S: * LIST (\Noselect) «/» /
    S: A103 OK LIST Completed
    C: A202 LIST

    /Mail/ %
    S: * LIST (\Noselect) «/»

    /Mail/meetings
    S: A202 OK LIST completed

    5.3.9. Команда LSUB

    Аргументы: имя-шаблон,
    имя почтового ящика может содержать символы подмены (wildcards).
    Отклики: немаркированный отклик: LSUB

    Результат: OK команда успешно исполнена;
    NO команда не прошла: не возможна выдача списка для предлагаемого шаблона или имени;
    BAD команда неизвестна или неверен аргумент.

    Команда LSUB возвращает субнабор имен из списка пользователя, который декларирован как «активный» или «подписной». При этом отправляется нуль или более немаркированных откликов LSUB. Аргументы LSUB имеют тот же формат, что и для команды LIST.

    Сервер может проверить имена из подписного листа с тем, чтобы проверить, существуют ли они еще. Если имени не существует, оно должно быть помечено в отклике LSUB атрибутом \Noselect. Сервер не должен по своему усмотрению удалять имена почтовых ящиков из подписного листа даже, если такого ящика более не существует.

    Пример: C: A002 LSUB «# news.» «comp.mail.*»
    S: * LSUB () «.» #news.comp.mail.mime
    S: * LSUB () «.» #news.comp.mail.misc
    S: A002 OK LSUB completed

    5.3.10. Команда STATUS

    Аргументы: имя почтового ящика, статусная информация имен.
    Отклики: немаркированные отклики: STATUS.
    Результат: OK — команда успешно выполнена;
    NO — команда не прошла: нет статусной информации для данного имени;
    BAD — команда неизвестна или неверен аргумент.

    Команда STATUS запрашивает статусные данные для указанного почтового ящика. Она не изменяет выбор почтового ящика и не вносит каких-либо изменений в состояние сообщений для запрошенного ящика (в частности команда STATUS не должна вызывать потерю флага \Recent).

    Команда STATUS предоставляет альтернативу открытию дополнительного IMAP 4.1 соединения и реализует команду EXAMINE для запрашиваемого почтового ящика, не изменяя выбора, выполненного при первичном соединении.

    В отличии от команды LIST, команда STATUS не гарантирует быстрого отклика. В некоторых реализациях сервер обязан открыть почтовый ящик в режиме «только чтение», чтобы получить нужные статусные данные. Кроме того, команда STATUS не допускает символов подмены в шаблоне имени. В настоящее время определены следующие статусные данные, которые могут быть запрошены:

    MESSAGES Число сообщений в почтовом ящике
    RECENT Число сообщений с установленным флагом \Recent
    UIDNEXT Следующее значение, которое будет предписано новому сообщению в почтовом ящике. Гарантируется, что это значение не изменится, если только в ящик не будет положено новое сообщение. UID будет изменен при укладке нового сообщения, даже если оно после этого стерто.
    UIDVALIDITY Уникальный валидатор почтового ящика
    UNSEEN Число сообщений, не имеющих установленного флага \Seen

    Пример: C: A042 STATUS blurdybloop (UIDNEXT MESSAGES)
    S: * STATUS blurdybloop (MESSAGES 231 UIDNEXT 44292)
    S: A042 OK STATUS completed

    5.3.11. Команда APPEND

    Аргументы : имя почтового ящика,
    опционно — флаг списка со скобками,
    опционно — строка даты и времени,
    литерал сообщения

    Отклики : команда не требует какого-либо специального отклика

    Результат: OK команда успешно исполнена
    NO команда не прошла: добавление в почтовый ящик не удалось, ошибка во флагах или дате/времени, или в тексте сообщения
    BAD команда неизвестна или неверен аргумент

    Команда APPEND добавляет литеральный аргумент в качестве нового сообщения в почтовый ящик. Этот аргумент должен следовать формату сообщений [RFC-822]. Допускается использование в сообщениях 8-битовых символов. Реализация сервера, которая не может работать с 8-битовыми данными, должна быть способна преобразовывать 8-битовую информацию APPEND в 7-битовую, используя транспортное кодирование [MIME-IMB]. Если специфицирован флаг списка со скобками, в результирующих сообщениях должны быть установлены флаги, в противном случае список флагов будет установлен по умолчанию пустым.

    Если специфицировано date_time, в результирующем сообщении должна быть установлена внутренняя дата, в противном случае, внутренняя дата и время результирующего сообщения будут установлены по умолчанию равными текущим значениям. Если команда append по какой-то причине не прошла, почтовый ящик должен быть возвращен в состояние, которое он имел до команды APPEND.

    Если почтовый ящик места назначения не существует, сервер должен сообщить об ошибке, а не должен автоматически создавать новый почтовый ящик. Если не ясно, может или нет быть создан почтовый ящик, сервер должен послать код отклика «[TRYCREATE]» в качестве префикса текста маркированного отклика NO. Это указывает клиенту на возможность попытки исполнения команды CREATE, после чего, в случае успеха, повторить команду APPEND.

    Если в настоящее время почтовый ящик и выбран, то немедленно должны начаться почтовые операции. Сервер должен уведомить клиента об этом, послав немаркированный отклик EXISTS. Если сервер не делает этого, клиент после одной или более команд APPEND может выдать команду NOOP (или при неудаче команду CHECK).

    Пример: C: A003 APPEND saved-messages (\Seen) <310>
    C: Date: Mon, 7 Feb 1994 21:52:25 -0800 (PST)
    C: From: Fred Foobar
    C: Subject: afternoon meeting
    C: To: mooch@owatagu.siam.edu
    C: Message-Id:
    C: MIME-Version: 1.0
    C: Content-Type: TEXT/PLAIN; CHARSET=US-ASCII
    C:
    C: Hello Joe, do you think we can meet at 3:30 tomorrow?
    C:
    S: A003 OK APPEND completed

    Замечание: команда APPEND не используется для доставки сообщений, так как она не содержит в себе механизма передачи служебной информации [SMTP].

    5.4. Команды клиента в состоянии «выбор сделан»

    В состоянии «выбор сделан», разрешены команды, которые манипулируют сообщениями в почтовом ящике. Помимо универсальных команд (CAPABILITY, NOOP и LOGOUT), а также команд режима аутентификации (SELECT, EXAMINE, CREATE, DELETE, RENAME, SUBSCRIBE, UNSUBSCRIBE, LIST, LSUB, STATUS и APPEND), в данном режиме доступны следующие команды: CHECK, CLOSE, EXPUNGE, SEARCH, FETCH, STORE, COPY и UID.

    5.4.1. Команда CHECK

    Аргументы: отсутствуют.
    Отклики: команда не требует какого-либо специального отклика;
    Результат: OK — проверка завершена;
    BAD — команда неизвестна или неверен аргумент.

    Команда CHECK осуществляет проверку выбранного почтового ящика. Проверка относится к любым характеристикам, зависящим от реализации (например, выявление положения почтового ящика в памяти сервера и на диске). Если сервер не поддерживает таких возможностей, команда эквивалентна NOOP.

    Не существует гарантии, что в результате CHECK будет прислан немаркированный отклик. Для проверки поступления новой почты следует использовать команду NOOP, а не CHECK.

    Пример: C: FXXZ CHECK
    S: FXXZ OK CHECK Completed

    5.4.2. Команда CLOSE

    Аргументы: отсутствуют.
    Отклики: команда не требует какого-либо специального отклика.
    Результат: OK — команда выполнена, система в состоянии «аутентификация выполнена»;
    NO — команда не прошла, никакого ящика не выбрано;
    BAD — команда неизвестна или неверен аргумент.

    Команда CLOSE навечно удаляет из выбранного почтового ящика все сообщения, помеченные флагом \Deleted, и возвращает систему в состояние «аутентификация выполнена». Никакого немаркированного отклика EXPUNGE не посылается.

    Никаких сообщений не удаляется и никаких флагов ошибки не возвращается, если почтовый ящик был выбран командой EXAMINE или находился в режиме «только для чтения».

    Даже если почтовый ящик выбран, команды SELECT, EXAMINE или LOGOUT могут быть использованы без предварительного исполнения команды CLOSE. Команды SELECT, EXAMINE и LOGOUT безоговорочно закрывают выбранный в данный момент почтовый ящик без удаления сообщений. Однако когда удалено много сообщений, последовательность CLOSE-LOGOUT или CLOSE-SELECT значительно быстрее, чем EXPUNGE-LOGOUT или EXPUNGE-SELECT, так как здесь не посылается никаких немаркированных откликов EXPUNGE (которые клиент вероятно проигнорирует).

    Пример: C: A341 CLOSE
    S: A341 OK CLOSE completed

    5.4.3. Команда EXPUNGE

    Аргументы: отсутствуют.
    Отклики: немаркированные отклики: EXPUNGE.
    Результат: OK — команда успешно завершена;
    NO — команда не прошла: стирание не выполнено (например, запрещено);
    BAD — команда неизвестна или неверен аргумент.

    Команда EXPUNGE навечно удаляет из выбранного почтового ящика все сообщения, которые помечены флагами \Deleted. Прежде чем выдать клиенту сигнал OK, посылается немаркированный отклик EXPUNGE для каждого из удаляемых сообщений.

    Пример: C: A202 EXPUNGE
    S: * 3 EXPUNGE
    S: * 3 EXPUNGE
    S: * 5 EXPUNGE
    S: * 8 EXPUNGE
    S: A2 02 OK EXPUNGE completed

    Замечание: в этом примере, сообщения 3, 4, 7 и 11 имеют установленный флаг \Deleted. Следует учитывать, что после каждого удаления сообщения перенумеруются.

    Аргументы: опционны, [CHARSET]-спецификация.
    Критерии поиска (один или более).
    Отклики: необходим немаркированный отклик: SEARCH.
    Результат: OK — поиск завершен;
    NO — ошибка: поиск для данного набора символов или критериев не возможен;
    BAD — команда неизвестна или неверен аргумент

    Команда SEARCH ищет почтовый ящик, который отвечает выбранным критериям отбора. Критерий отбора состоит из одного или более ключей поиска. Немаркированный отклик SEARCH от сервера содержит список номеров сообщений, которые соответствуют критериям отбора.

    Когда специфицировано несколько ключей, результатом является (функция AND) совокупность всех сообщений, отвечающим заданным критериям. Например, критерий DELETED FROM «SMITH» SINCE 1-Feb-1994 относится ко всем стертым сообщениям от Смита, которые были положены в почтовый ящик после 1-го февраля 1994. (например, для объединения этих ключей с помощью функций OR и NOT).

    Опционная спецификация [CHARSET] состоит из слова «CHARSET», за которым следует зарегистрированное наименование символьного набора [CHARSET]. Он включает в себя [CHARSET] строк, которые используются в качестве критерия отбора. Транспортное кодирование содержимого [MIME-IMB] и строки [MIME-HDRS] в [RFC-822]/[MIME-IMB] заголовках, должны декодироваться перед сравнением текста в представлении [CHARSET], отличном от US-ASCII. US-ASCII должно поддерживаться всегда, но могут использоваться и другие символьные наборы. Если сервер не поддерживает специфицированный набор символов [CHARSET], он должен вернуть маркированный отклик NO (но не BAD).

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

    Сообщения с номерами, соответствующими специфицированному набору номеров
    ALL Все сообщения в почтовом ящике. Ключ отбора по умолчанию для применения команд AND
    ANSWERED Сообщения с установленным флагом \Answered.
    BCC Сообщения, которые содержат специфицированную строку в поле BCC структуры заголовка сообщения.
    BEFORE Сообщения, чьи внутренние даты раньше указанной.
    BODY Сообщения, которые содержат специфицированную строку в теле сообщения.
    CC Сообщения, которые содержат специфицированную строку в CC поле заголовка.
    DELETED Сообщения с установленным флагом \Deleted.
    DRAFT Сообщения с установленным флагом \Draft.
    FLAGGED Сообщения c установленным флагом \Flagged.
    FROM Сообщения, которые содержат специфицированную строку в поле FROM заголовка.
    HEADER Сообщения, которые содержат заголовок со специфицированным именем поля (в соответствии с [RFC-822]) и специфицированную строку в теле данного поля.
    KEYWORD Сообщения со специфицированным ключевыми словами.
    LARGER Сообщения с размером [RFC-822] больше чем специфицированное число октетов.
    NEW Сообщения, которые имеют установленный флаг \Recent, но не имеют флага \Seen. Это функционально эквивалентно «(RECENT UNSEEN)».
    NOT Сообщения, которые не содержат специфицированного ключевого слова.
    OLD Сообщения, которые не имеют флага \Recent. «NOT RECENT» (противоположно «NOT NEW»).
    ON Сообщения, чья внутренняя дата соответствует специфицированному значению даты.
    OR Сообщения, которые соответствуют любому из ключевых слов поиска.
    RECENT Сообщения, которые имеют установленный флаг \Recent.
    SEEN Сообщения, которые имеют установленный флаг \Seen.
    SENTBEFORE Сообщения, чье содержимое заголовка, соответствует дате ранее специфицированного значения [RFC-822].
    SENTON Сообщения, чье содержимое заголовка, соответствует специфицированной дате [RFC-822]
    SENTSINCE Сообщения, чье содержимое заголовка, соответствует [RFC-822]: специфицированному значению даты или позже.
    SINCE Сообщения, чья внутренняя дата соответствует или позже специфицированного значения.
    SMALLER Сообщения с размером [RFC-822] меньше чем специфицированное число октетов.
    SUBJECT Сообщения, которое содержит специфицированную строку в поле SUBJECT заголовка.
    TEXT Сообщения, которые содержат специфицированную строку в заголовке или теле сообщения
    TO Сообщения, которые содержат специфицированную строку в поле заголовка TO.
    UID Сообщения с уникальными идентификаторами, соответствующими заданному значению идентификатора.
    UNANSWERED <>Сообщения, которые не имеют флага \Answered.
    UNDELETED Сообщения, которые не имеют флага \Deleted.
    UNDRAFT Сообщения, которые не имеют флага \Draft.
    UNFLAGGED Сообщения, которые не имеют флага \Flagged.
    UNKEYWORD Сообщения, которые не содержат заданных ключевых слов.
    UNSEEN Сообщения, которые не имеют флага \Seen.

    Пример: C: A282 SEARCH FLAGGED SINCE 1-Feb-1994 NOT FROM «Smith»
    S: * SEARCH 2 84 882
    S: A282 OK SEARCH completed

    5.4.5. Команда FETCH

    Аргументы: набор сообщений,
    имена информационных сообщений.
    Отклики: немаркированные отклики: FETCH
    Результат: OK — операция успешно завершена;
    NO — команда не прошла: не удалось доставить эти данные;
    BAD — команда неизвестна или неверен аргумент.

    Команда FETCH извлекает данные, соответствующие сообщению в почтовом ящике. В качестве доставляемых данных может выступать отдельный атом или список элементов, помещенных в скобки. В настоящее время определены следующие типы данных, которые могут быть доставлены:

    ALL Эквивалентно: (FLAGS INTERNALDATE RFC822.SIZE ENVELOPE)
    BODY Нерасширяемая форма BODYSTRUCTURE.
    BODY[ ]

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

    HEADER, HEADER.FIELDS, HEADER.FIELDS.NOT, MIME и TEXT. Пустая спецификация относится ко всему сообщению, включая заголовок.

    Каждое сообщение имеет номер, по крайней мере, одной части.

    Сообщения не-[MIME-IMB] и несоставные сообщения [MIME-IMB] без инкапсуляции имеют только часть 1.

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

    Спецификаторы частей HEADER, HEADER.FIELDS, HEADER.FIELDS.NOT и TEXT являются базовыми. Перед ними могут размещаться один или более числовых спецификаторов частей сообщения, которые указывают на принадлежность типу MESSAGE/RFC822. Перед спецификатором части MIME должны размещаться один или более числовых спецификаторов. Спецификаторы частей HEADER, HEADER.FIELDS, HEADER.FIELDS.NOT относятся к заголовку сообщения [RFC-822] или инкапсулированному сообщению [MIME-IMT] MESSAGE/RFC822. За HEADER.FIELDS и HEADER.FIELDS.NOT следует список имен полей (как это определено в [RFC-822]). Субнабор, возвращаемый HEADER.FIELDS, содержит только те поля заголовка, имена которых соответствуют одному из имен списка. Аналогично, субнабор, возвращаемый HEADER.FIELDS.NOT, содержит только поля заголовка с несоответствующими именами полей. Соответствие является точным, но нечувствительным к использованию строчных и прописных букв. Во всех случаях, вставляется разграничивающая пустая строка между заголовком и телом сообщения.

    Спецификатор MIME части относится к заголовку [MIME-IMB] этой части. Спецификатор текстовой части относится к телу сообщения, без заголовка [RFC-822]. Ниже приведен пример составного сообщения с некоторыми спецификаторами его частей:

    HEADER ([RFC-822] заголовок сообщения)
    TEXT MULTIPART/MIXED
    1 TEXT/PLAIN
    2 APPLICATION/OCTET-STREAM
    3 MESSAGE/RFC822
    3.HEADER ([RFC-822] заголовок сообщения)
    3.TEXT ([RFC-822] текстовое тело сообщения)
    3.1 TEXT/PLAIN
    3.2 APPLICATION/OCTET-STREAM
    4 MULTIPART/MIXED
    4.1 IMAGE/GIF
    4.1.MIME ([MIME-IMB] заголовок для IMAGE/GIF)
    4.2 MESSAGE/RFC822
    4.2.HEADER ([RFC-822] заголовок сообщения)
    4.2.TEXT ([RFC-822] текстовое тело сообщения)
    4.2.1 TEXT/PLAIN
    4.2.2 MULTIPART/AL TERNATIVE
    4.2.2.1 TEXT/PLAIN
    4.2.2.2 TEXT/RICHTEXT

    Имеется возможность доставить субстроку определенного текста. Это делается путем присоединения к спецификатору части открытой угловой скобки (» сообщения длиной 1500 октетов пришлет BODY[] с литералом размера 1500, а не BODY[].

    BODY.PEEK[ ] Альтернативная форма BODY[ ], которая не устанавливает флаг \Seen.
    BODYSTRUCTURE Структура тела сообщения [MIME-IMB]. Она вычисляется сервером путем разбора полей заголовка [MIME-IMB] [RFC-822] и заголовков [MIME-IMB].
    ENVELOPE Структура заголовка сообщения. Она вычисляется сервером в результате разбора заголовка [RFC-822] на части, присваивая им значения по умолчания, если это необходимо.
    FAST Макро эквивалент (FLAGS INTERNALDATE RFC822.SIZE)
    FLAGS Флаги, присвоенные сообщению.
    FULL Макро эквивалент (FLAGS INTERNALDATE RFC822.SIZE ENVELOPE BODY)
    INTERNALDATE Внутренняя дата сообщения.
    RFC822 Функционально эквивалентно BODY[], отличается по синтаксису результирующих немаркированных данных FETCH (возвращается RFC822).
    RFC822.HEADER Функционально эквивалентно BODY.PEEK[HEADER], отличается по синтаксису результирующих немаркированных данных FETCH (возвращает данные в формате RFC822.HEADER).
    RFC822.SIZE Размер сообщения [RFC-822].
    RFC822.TEXT Функционально эквивалентно BODY[TEXT], отличается по синтаксису результирующих немаркированных данных FETCH (возвращается RFC822.TEXT).
    UID Уникальный идентификатор сообщения.

    Пример: C: A654 FETCH 2:4 (FLAGS BODY[HEADER.FIELDS (DATE FROM)])
    S: * 2 FETCH .
    S: * 3 FETCH .
    S: * 4 FETCH .
    S: A654 OK FETCH completed

    5.4.6. Команда STORE

    Аргументы: набор сообщений,
    имя элемента сообщения,
    значение элемента сообщения.
    Отклики: немаркированные отклики: FETCH.
    Результат: OK — операция успешно завершена;
    NO — команда не прошла: данные не могут быть запомнены;
    BAD — команда неизвестна или неверен аргумент.

    Команда STORE заносит данные в почтовый ящик. В норме команда STORE возвращает обновленную версию данных с немаркированным откликом FETCH. «.SILENT» в имени элемента данных блокирует немаркированный отклик FETCH, и сервер должен предполагать, что клиент определил обновленное значение сам или ему обновленное значение не нужно.

    Замечание: вне зависимости от того используется или нет суффикс «.SILENT», сервер должен послать немаркированный отклик FETCH, если внешние причины вызвали изменение флагов сообщения.

    В настоящее время определены следующие элементы данных:

    FLAGS Заменить флаги для сообщения, приведенного в аргументе. Новое значение флагов присылается, как если бы выполнялась команда FETCH для этих флагов.
    FLAGS.SILENT Эквивалентно FLAGS, но без возвращения нового значения.
    +FLAGS Добавить аргумент к флагам сообщения. Новое значение флагов возвращается, как при исполнении команды FETCH.
    +FLAGS.SILENT Эквивалентно +FLAGS, но без возвращения нового значения.
    -FLAGS Удаляет аргумент из флагов сообщения. Новое значение флагов возвращается, как при исполнении команды FETCH.
    -FLAGS.SILENT Эквивалентно -FLAGS, но без возвращения нового значения.

    Пример: C: A003 STORE 2:4 +FLAGS (\ Deleted)
    S: * 2 FETCH FLAGS (\Deleted \Seen)
    S: * 3 FETCH FLAGS (\Deleted)
    S: * 4 FETCH FLAGS (\Deleted \Flagged \Seen)
    S: A003 OK STORE completed

    5.4.7. Команда COPY

    Аргументы: набор сообщений,
    имя почтового ящика.
    Отклики: команда не требует какого-либо специального отклика.

    Результат: OK команда успешно завершена;
    NO команда не прошла: не могут быть скопированы эти сообщения вообще или в данный почтовый ящик;
    BAD команда неизвестна или неверен аргумент.

    Команда COPY копирует специфицированное сообщение в конец указанного почтового ящика. Флаги и внутренняя дата сообщения должны быть сохранены в копии.

    Если указанный почтовый ящик отсутствует, сервер должен прислать сообщение об ошибке. Он не должен автоматически создавать почтовый ящик. Если заведомо не известно, что ящик не может быть создан, сервер должен послать код отклика «[TRYCREATE]» в качестве префикса текста маркированного отклика NO. Это предлагает клиенту возможность исполнить команду CREATE, после чего в случае успешного завершения повторно исполнить COPY.

    Если команда COPY не прошла по какой-то причине, сервер должен восстановить почтовый ящик назначения в состояние, которое он имел до выполнения COPY.

    Пример: C: A003 COPY 2:4 MEETING
    S: A003 OK COPY completed

    5.4.8. Команда U >Аргументы: имя команды,
    аргументы команды.
    Отклики: немаркированные отклики: FETCH, SEARCH.
    Результат: OK — команда UID завершена;
    NO — команда UID не прошла;
    BAD — команда неизвестна или неверен аргумент.

    Команда UID имеет две формы. В первой форме она использует в качестве аргумента имена команд COPY, FETCH или STORE (с их аргументами). Однако числа в списке аргументов в этом случае представляют собой уникальные идентификаторы, а не порядковые номера сообщений.

    Во второй форме команда UID использует команду SEARCH с ее аргументами. Интерпретация аргументов та же, что и в случае SEARCH; однако, числа, возвращаемые в отклике на команду UID SEARCH, представляют собой уникальные идентификаторы, а не порядковые номера сообщений. Например, команда UID SEARCH 1:100 UID 443:557 возвратит уникальный идентификатор, соответствующий пересечению порядкового номера сообщения 1:100 и UID 443:557.

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

    Число после «*» в немаркированном отклике FETCH всегда является порядковым номером сообщения, а не уникальным идентификатором, даже для отклика на команду UID. Однако реализации сервера должны безоговорочно включать значения UID в качестве части любого отклика FETCH, вызванного командой UID, вне зависимости от того, был ли UID специфицирован в качестве элемента сообщения для FETCH.

    Пример: C: A999 UID FETCH 4827313:4828442 FLAGS
    S: * 23 FETCH (FLAGS (\Seen) UID 4827313)
    S: * 24 FETCH (FLAGS (\Seen) UID 4827943)
    S: * 25 FETCH (FLAGS (\Seen) UID 4828442)
    S: A999 UID FETCH completed

    5.5. Команды клиента — экспериментальные и расширения
    5.5.1. Команда X

    Аргументы: определяется приложением.
    Отклики: определяется приложением.
    Результат: OK — команда выполнена;
    NO — отказ;
    BAD — команда неизвестна или неверен аргумент.

    Любая команда с префиксом X является экспериментальной командой. Команды, которые не являются частью этой спецификации стандарта, модификации стандарта или одобренного IESG экспериментального протокола, должны использовать префикс X.

    Любой добавленный немаркированный отклик, посланный экспериментальной командой также должен иметь префикс X. Реализации сервера не должны посылать такие немаркированные отклики, если только клиент не запрашивает их посредством какой-либо экспериментальной команды.

    Пример: C: a441 CAPABILITY
    S: * CAPABILITY IMAP4rev1 AUTH=KERBEROS_V4 XPIG-LATIN
    S: a441 OK CAPABILI TY completed
    C: A442 XPIG-LATIN
    S: * XPIG-LATIN ow-nay eaking-spay ig-pay atin-lay
    S: A442 OK XPIG-LATIN completed-cay

    6. Отклики сервера

    Существует три вида откликов сервера: отклики состояния, информация сервера и запрос продолжения команды. Информация, содержащаяся в отклике сервера, идентифицируется словом «Содержимое:».

    Клиент должен быть готов воспринять любой отклик в любое время. Отклики состояния могут быть маркированными или нет. Маркированные отклики состояния указывают на результат завершения команды клиента (OK, NO или BAD) и имеют метку, соответствующую команде.

    Некоторые отклики состояния и любая информация сервера не маркируются. Немаркированный отклик выделяется символом «*» вместо метки. Немаркированные отклики состояния отмечают реакцию сервера, они не указывают на завершение выполнения команды (например, предупреждение о предстоящем отключении системы). По историческим причинам немаркированные информационные отклики сервера называются также «незапрашиваемыми данными».

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

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

    Немаркированная информация посылается сервером, когда соединение IMAP находится в состоянии «выбрано». В этом состоянии при выполнении команды сервер проверяет наличие новых сообщений в выбранном почтовом ящике. В норме, это часть процедуры выполняется любой командой, следовательно, даже команды NOOP достаточно для проверки наличия новых сообщений. Если обнаружены новые сообщения, сервер посылает немаркированные отклики EXISTS и RECENT, отражающие новые размеры почтового ящика. Реализации сервера, которые предлагают множественный одновременный доступ к одному и тому же ящику, также должны посылать соответствующие немаркированные отклики FETCH и EXPUNGE, если другие агенты изменяют состояние любого флага сообщения или удаляют любое сообщение.

    Отклики запросов продолжения команды используют символ «+» вместо метки. Эти отклики посылаются сервером для индикации приема незавершенной команды клиента и готовности приема остальной части команды.

    6.1. Отклики сервера — отклики состояния

    Статусными откликами являются OK, NO, BAD, PREAUTH и BYE. OK, NO и BAD могут быть маркированными или нет. PREAUTH и BYE — всегда не маркированы.

    Статусные отклики могут включать опционный код отклика. Код отклика состоит из информации, заключенной в квадратные скобки, в форме атома. Далее может следовать пробел и аргументы. Код отклика содержит дополнительную информацию или статусные коды для программы клиента помимо условий OK/NO/BAD. Эти данные определяются, когда клиент может предпринять действия на основе этой дополнительной информации. В настоящее время определены следующие коды откликов:

    ALERT Текстовое сообщение, содержащее специальное предупреждение, которое должно быть представлено пользователю в форме, привлекающей внимание.
    NEWNAME За этим откликом следует имя почтового ящика и новое имя. Команды SELECT или EXAMINE не пройдут, так как ящик места назначения более не существует из-за переименования. Это является указанием для клиента, попытаться повторить команду с новым именем почтового ящика.
    PARSE Текстовое сообщение, которое указывает на ошибку при разборе заголовка [RFC-822] или заголовка [MIME-IMB] сообщения в почтовом ящике.
    PERMANENTFLAGS Когда за этим кодом следует в скобках список флагов, это указывает, какие из известных флагов могут быть изменены на постоянной основе. Любые флаги, которые указаны в немаркированном отклике FLAGS, но отсутствуют в списке PERMANENTFLAGS, могут быть установлены на постоянной основе. Если клиент пытается запомнить (STORE) флаг, который отсутствует в списке PERMANENTFLAGS, сервер либо отвергнет этот запрос с помощью отклика NO или запомнит состояние только до конца текущей сессии. Список PERMANENTFLAGS может также включать специальный флаг \*, который указывает, что имеется возможность создать новые ключевые слова путем записи этих флагов в почтовом ящике.
    READ-ONLY Почтовый ящик выбран в режиме только для чтения или доступ к нему был сменен с read-write на read-only.
    READ-WRITE Почтовый ящик находится в режиме read-write, или доступ к нему был сменен с read-only на read-write.
    TRYCREATE Попытка выполнения APPEND или COPY оказалась неуспешной из-за того, что почтовый ящик места назначения отсутствует. Это указывает клиенту, что операция может оказаться успешной, если почтовый ящик будет сначала создан с помощью CREATE
    UIDVALIDITY Когда за этим кодом следует десятичное число, это указывает на значение уникального идентификатора.
    UNSEEN Когда за этим кодом следует десятичное число, это указывает на значение номера первого сообщения без флага \Seen.

    Дополнительные коды откликов определенные конкретным клиентом или сервером должны иметь префикс «X», если они отклоняются от рекомендаций данного документа. Реализации клиента должны игнорировать отклики, которые ими не распознаются.

    6.1.1. Отклик OK

    Содержимое: опционный код отклика;
    текст, читаемый человеком

    Отклик OK индицирует информационное сообщение от сервера. Если оно маркировано, сообщение указывает на успешное завершение соответствующей команды. Пользователю может быть предложено текстовое информационное сообщение. Немаркированная форма указывает на чисто информационное сообщение; природа информации может быть указана в коде отклика.

    Немаркированная форма используется также как один из трех видов оповещения об установлении начального соединения. Эта форма указывает, что еще не выполнена аутентификация и необходима команда LOGIN.

    Пример: S: * OK IMAP4rev1 server ready
    C: A001 LOGIN fred blurdybloop
    S: * OK [ALERT] System shutdown in 10 minutes
    S: A001 OK LOGIN Completed

    6.1.2. Отклик NO

    Содержимое: опционный код отклика;
    текст, читаемый человеком

    Отклик NO указывает на сообщение от сервера об операционной ошибке. В помеченной форме он отмечает неудачное завершение соответствующей команды. Непомеченная форма служит для индикации предупреждения, команда все еще может завершиться успешно. Текстовое сообщение описывает условия.

    Пример: C: A222 COPY 1:2 owatag usiam
    S: * NO Disk is 98% full, please delete unnecessary data
    S: A222 OK COPY completed
    C: A223 COPY 3:200 blurdybloop
    S: * NO Disk is 98% full, please delete unnecessary data
    S: * NO Disk is 99% full, please delete unnecessary data
    S: A223 NO COPY failed: disk is full

    6.1.3. Отклик BAD

    Содержимое: опционный код отклика;
    текст, читаемый человеком

    Отклик BAD отмечает сообщение об ошибке со стороны сервера. В маркированной форме он сообщает об ошибке протокольного уровня в команде клиента; метка отмечает команду, которая вызвала ошибку. Непомеченная форма указывает на ошибку протокольного уровня, для которой нельзя указать команду, вызвавшую ошибку; это может также означать внутреннюю ошибку сервера. Текстовое сообщение описывает условия.

    Пример: C: . very long command line.
    S: * BAD Command line too long
    C: . empty line.
    S: * BAD Empty command line
    C: A443 EXPUNGE
    S: * BAD Disk crash, attempting salvage to a new disk!
    S: * OK Salvage successful, no data lost
    S: A443 OK Expunge completed

    6.1.4. Отклик PREAUTH

    Содержимое: опционный код отклика;
    текст, читаемый человеком

    Отклик PREAUTH является всегда непомеченным и представляет собой одну из трех возможных реакций при установлении соединения. Он указывает, что для соединения уже выполнена аутентификация, и команда LOGIN не нужна.

    Пример: S: * PREAUTH IMAP4rev1 server logged in as Smith

    6.1.5. Отклик BYE

    Содержимое: опционный код отклика;
    текст, читаемый человеком

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

    1. Как часть нормальной процедуры logout. Сервер закроет соединение после отправки маркированного отклика OK на команду LOGOUT.
    2. Как уведомление об аварийном прерывании сессии. Сервер немедленно разрывает соединение.
    3. Как уведомление о процедуре автоматического logout по причине отсутствия активности. Сервер немедленно разрывает соединение.
    4. Как одно из трех возможных сообщений при установлении соединения, уведомляя, что сервер не может установить соединение с данным клиентом. Сервер немедленно разрывает соединение.

    Отличие между откликом BYE, который является частью обычной процедуры LOGOUT (первый вариант), и BYE при отказе (остальные три варианта), заключается в том, что соединение в последнем случае разрывается немедленно.

    Пример: S: * BYE Autologout; idle for too long

    6.2. Отклики сервера — сообщения о состоянии сервера и почтового ящика

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

    6.2.1. Отклик CAPABILITY

    Содержимое: список возможностей.

    Отклик CAPABILITY возникает в результате исполнения одноименной команды. Список возможностей, содержащийся в перечне наименований, разделенных пробелами, характеризует функции, поддерживаемые сервером. Список возможностей должен включать в себя атом «IMAP 4.1».

    Имя возможности, которое начинается с «AUTH=» указывает, что сервер поддерживает данный механизм аутентификации. Другие наименования возможностей отмечают, что сервер поддерживает расширение, модификацию или усовершенствования протокола IMAP 4.1. Отклик сервера должен соответствовать данному документу до тех пор, пока клиент использует команды, согласованные со списком возможностей.

    Имена возможностей должны либо начинаться с «X», либо быть стандартными, либо соответствовать расширениям IMAP 4.1, модификациям или усовершенствованиям, зарегистрированным IANA. Сервер не должен предлагать незарегистрированные или нестандартные имена возможностей, если их имена не начинаются с символа «X».

    Реализациям клиента не следует требовать каких-либо имен возможностей, отличных от «IMAP 4.1», они должны игнорировать неизвестные имена возможностей.

    Пример: S: * CAPABILITY IMAP4rev1 AUTH=KERBEROS_V4 XPIG-LATIN

    6.2.2. Отклик LIST

    Содержимое: атрибуты имени, иерархический разделитель, имя.

    Отклик LIST посылается как результат команды LIST. Он возвращает одно имя, которое соответствует спецификации LIST. Допускается несколько откликов LIST на одну команду.

    Определено четыре атрибута имени:

    \Noinferiors Дочерние уровни иерархии не могут иметь то же самое имя. Не существует дочерних уровней в настоящее время, и они не могут быть созданы в будущем.
    \Noselect Не допускается использование данного имени для именования почтового ящика, который может быть выбран.
    \Marked Почтовый ящик помечен сервером как «interesting»; почтовый ящик, вероятно, содержит сообщения, которые добавлены со времени, когда почтовый ящик последний раз был выбран.
    \Unmarked Почтовый ящик не содержит каких-либо дополнительных сообщений, со времени, когда почтовый ящик последний раз был выбран.

    Если сервер не может определить, является ли почтовый ящик «интересным», или, если имя имеет атрибут \Noselect, сервер не должен посылать отклики \Marked или \Unmarked. Иерархическим разделителем является символ, используемый для разграничения уровней иерархии имен почтового ящика. Клиент может использовать разделитель для формирования дочерних уровней в почтовом ящике, а также для поиска в иерархической системе имен. Все дочерние уровни верхнего уровня иерархии должны использовать один и тот же тип разделителя. Иерархический разделитель NIL означает, что никакой иерархии нет.

    Имя представляет собой однозначную иерархию (слева направо) и должно быть пригодным для использования в качестве шаблона командами LIST и LSUB. Если не использован атрибут \Noselect, имя должно быть пригодно в качестве аргумента команд, типа SELECT, которые требуют ввода имени почтового ящика.

    Пример: S: * LIST (\ Noselect) «/»

    6.2.3. Отклик LSUB

    Содержимое: атрибуты имени, иерархический разграничитель, имя.

    Отклик LSUB является результатом команды LSUB. Он возвращает одно имя, которое соответствует спецификации LSUB. Допускается несколько откликов на одну команду LSUB. Формат данных идентичен используемому в отклике LIST.

    Пример: S: * LSUB () «.» #news.comp.mail.misc

    6.2.4. Отклик STATUS

    Содержимое: имя, статусный список, заключенный в скобки.

    Отклик STATUS является результатом команды STATUS. Он возвращает имя почтового ящика, которое соответствует спецификации STATUS, и запрашиваемую статусную информацию почтового ящика.

    Пример: S: * STATUS blurdybloop (MESSAGES 231 UIDNEXT 44292)

    Содержимое: нуль или более чисел.

    Отклик SEARCH является результатом команды SEARCH или UID SEARCH. Числа относятся к тем сообщениям, которые отвечают критериям отбора. Для SEARCH это порядковые номера сообщений, а для UID SEARCH — их уникальные идентификаторы. Числа отделяются друг от друга пробелами.

    Пример: S: * SEARCH 2 3 6

    6.2.6. Отклик FLAGS

    Содержимое: список флагов, заключенный в скобки.

    Отклик FLAGS является результатом команды SELECT или EXAMINE. Список флагов, заключенный в скобки определяет флаги (системные флаги), которые могут использоваться для данного почтового ящика. Допускаются флаги, отличные от системных, это зависит от реализации сервера. Отклик FLAGS должен записываться клиентом.

    Пример: S: * FLAGS (\Answered \Flagged \Deleted \Seen \Draft)

    6.3. Отклики сервера — размер почтового ящика

    Эти отклики являются немаркированными. Они передают от сервера клиенту информацию об изменении размера почтового ящика. Число, которое следует за символом «*» определяет количество сообщений.

    6.3.1. Отклик EXISTS

    Отклик EXISTS сообщает о числе сообщений в почтовом ящике. Этот отклик является результатом команды SELECT, EXAMINE или изменения размера почтового ящика (например, получено новое почтовое сообщение). Отклик EXISTS должен регистрироваться клиентом.

    Пример: S: * 23 EXISTS

    6.3.2. Отклик RECENT

    Отклик RECENT сообщает число сообщений с флагами \Recent. Этот отклик является результатом команды SELECT, EXAMINE или изменения размера почтового ящика (например, получено новое почтовое сообщение).

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

    Единственным способом идентифицировать последние сообщения является рассмотрение флагов \Recent, или выполнение команды SEARCH RECENT. Информация отклика RECENT должна регистрироваться клиентом.

    Пример: S: * 5 RECENT

    6.4. Отклики сервера — статусное сообщение

    Эти отклики являются немаркированными. Они несут информацию о том, как сообщения доставляются от сервера к клиентам, и возникают как результат работы одноименных команд. Сразу за символом «*» следует число, которое является порядковым номером сообщения.

    6.4.1. Отклик EXPUNGE

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

    Как результат этого немедленного уменьшения порядковых номеров следует рассматривать то, что порядковые номера сообщений, появляющиеся при последующих командах EXPUNGE, зависят от того, в каком порядке удаляются сообщения. Например, если последние 5 сообщений в почтовом ящике с 9 сообщениями стерты, сервер, удаляющий записи «снизу-вверх» пошлет 5 немаркированных откликов EXPUNGE (с номером 5), в то время как сервер, стирающий записи «сверху вниз», пошлет немаркированные отклики с номерами 9, 8, 7, 6 и 5.

    Отклик EXPUNGE не должен посылаться, когда не исполняется никакая команда, или при отклике на команды FETCH, STORE или SEARCH. Это правило необходимо, чтобы предотвратить потерю синхронизации нумерации для клиента и сервера.

    Информация отклика EXPUNGE должна регистрироваться клиентом.

    Пример: S: * 44 EXPUNGE

    6.4.2. Отклик FETCH

    Содержимое: текст сообщения.

    Отклик FETCH возвращает данные о сообщении клиенту. Данные сформированы в группы из имени элемента и его значения в скобках. Этот отклик является следствием команды FETCH или STORE, а также одностороннего решения сервера (например, об изменении флагов). В настоящее время существуют следующие информационные элементы:

    BODY Форма BODYSTRUCTURE без расширения данных.
    BODY[ ] >

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

    Если специфицирован начальный октет, то это субстрока полного содержимого тела, начинающаяся с заданного октета. Это означает, что BODY[ ] может быть укорочено, но BODY[ ] никогда не укорачивается.

    Если идентификатор [CHARSET] является частью списка параметров тела секции, допустимы 8-битовые текстовые данные. Заметьте, что заголовки (спецификаторы частей HEADER, MIME или часть заголовка секции MESSAGE/RFC822), должны содержать только 7-битовые символы (применение 8-битовых символов в заголовке запрещено). Заметим также, что пустая строка в конце заголовка всегда включается в текст заголовка.

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

    BODYSTRUCTURE — список, заключенный в скобки, который описывает [MIME-IMB],
    структура тела сообщения.

    Эта структура вычисляется сервером путем разбора полей заголовка [MIME-IMB], и подставления при необходимости значений по умолчанию.

    Например, простое текстовое сообщение из 48 строк и 2279 октетов может иметь структуру тела: («TEXT» «PLAIN» («CHARSET» «US-ASCII») NIL NIL «7BIT» 2279 48)

    Если имеется несколько частей, они выделяются вложенными скобками. Вместо типа тела в качестве первого элемента списка используется тело с иерархической структурой. Вторым элементом списка, заключенного в скобки, является составной субтип (mixed, digest, parallel, alternative, и т.д.).

    Например, сообщение из двух частей, включающее в себя текст и приложение, закодированное в BASE64, может иметь структуру тела: ((«TEXT» «PLAIN» («CHARSET» «US-ASCII») NIL NIL «7BIT» 1152 23)(«TEXT» «PLAIN» («CHARSET» «US-ASCII» «NAME» «cc.diff») » » «Compiler diff» «BASE64» 4554 73) «MIXED»))

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

    Список параметров тела, заключенный в скобки.

    Список содержит пары атрибут/значение [например, («foo» «bar» «baz» «rag»), где «bar» представляет собой значение «foo», а «rag» является значением «baz»] как это определено в [MIME-IMB].

    Список, заключенный в скобки, состоящий из строки типа размещения, за которой следует список пар атрибут/значение. Имена типов размещения и атрибутов будут определены в будущих стандартах.

    Строка или список в скобках, определяющие язык, так как это задано в [LANGUAGE-TAGS].

    Любое из последующих расширений данных в данной версии протокола не определено. Такие расширения могут состоять из нуля или более NIL-строк, чисел, или вложенных списков таких данных, заключенных в скобки. Реализации клиента, которые осуществляют доставку BODYSTRUCTURE, должны быть готовы принять такие расширения данных. Реализации сервера не должны посылать такие расширения, до тех пор, пока они не войдут в новую версию протокола. Базовые поля несоставной части тела размещаются в следующем порядке:

    Строка, описывающая имя типа содержимого, как это определено в [MIME-IMB].

    Строка, описывающая имя субтипа, как это определено в [MIME-IMB].

    Список параметров тела, заключенный в скобки

    Список пар атрибут/значение, заключенный в скобки, [например, («foo» «bar» «baz» «rag»), где «bar» является значением «foo», а «rag» — значением «baz»], как это описано в [MIME-IMB].

    Строка, описывающая идентификатор содержимого, как это определено в [MIME-IMB].

    Строка, предоставляющая описание содержимого, как это задано в [MIME-IMB].

    Строка, предоставляющая транспортную кодировку, как это задано в [MIME-IMB].

    Число, указывающее размер тела в октетах. Заметьте, что этот размер характеризует размер тела с учетом транспортного кодирования. Размер исходного текста может быть иным.

    Тип тела MESSAGE и субтип RFC822 сразу после базовых полей содержат структуру заголовка, структуру тела и размер вложенного сообщения в строках.

    Тип тела TEXT сразу после базовых полей содержат размер тела в строках. Заметьте, что этот размер отражает размер фрагмента после выполнения транспортного кодирования.

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

    Данные расширения для несоставной части тела располагаются в следующем порядке:

    Строка, содержащая значение MD5 тела, как это описано в [MD5].

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

    Строка или список, заключенный в скобки, определяющие язык тела, как это задано в [LANGUAGE-TAGS].

    Любые последующие данные расширения пока не определены в данной версии протокола.

    ENVELOPE — список, заключенный в скобки, который описывает структуру заголовка (конверта) сообщения. Он вычисляется сервером в результате разбора заголовка [RFC-822], при необходимости некоторым полям присваиваются значения по умолчанию.

    Поля структуры конверта размещаются в следующем порядке: дата, subject (предмет сообщения), from (от), отправитель, reply-to (ответ на), to, cc, bcc, in-reply-to (в ответ на), и идентификатор сообщения. Поля дата, subject, in-reply-to и идентификатор сообщения являются строками. Поля from, отправитель, reply-to, to, cc и bcc являются списками адресных структур, заключенными в скобки.

    Адресная структура представляет собой список, который описывает электронный почтовый адрес. Поля адресной структуры размещаются в следующем порядке: персональное имя, [SMTP] @-домен (маршрут отправителя), имя почтового ящика и имя ЭВМ.

    Синтаксис группы [RFC-822] определяется специальной формой адресной структуры, в которой поле имени ЭВМ равно NIL. Если поле имени почтового ящика также равно NIL, это является концом группового маркера (двоеточие в синтаксисе RFC 822). Если поле имени почтового ящика не равно NIL, это обозначает начало группового маркера, а поле имени почтового ящика содержит имя группы.

    Любое поле в конверте или адресной структуре, которое не используется, характеризуется значением NIL. Заметим, что сервер должен заполнять по умолчанию поля reply-to и sender из поля from.

    FLAGS Список флагов, установленных для данного сообщения, заключенный в скобки.
    INTERNALDATE Строка, представляющая внутреннюю дату сообщения.
    RFC822 Эквивалент BODY[].
    RFC822.HEADER Эквивалент BODY.PEEK[HEADER].
    RFC822.SIZE Число, выражающее размер сообщения [RFC-822].
    RFC822.TEXT Эквивалент BODY[TEXT].
    UID Число, выражающее уникальный идентификатор сообщения.

    Пример: S: * 23 FETCH (FLAGS (\Seen) RFC822.SIZE 44827)

    6.5 Отклики сервера — запрос продолжения команды

    Отклик на запрос продолжения команды вместо метки выделяется символом «+». Эта форма отклика указывает на то, что сервер готов принять продолжение команды от клиента. Остальная часть этого отклика имеет текстовую форму.

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

    Клиенту не позволено посылать литеральные октеты, если только сервер в явной форме не запросил их. Это позволяет серверу обрабатывать команды и отвергать ошибки строчка за строчкой. Остальная часть команды, включая CRLF, завершающие команду, следует за октетами литерала. Если имеются какие-либо дополнительные аргументы команды, за литеральными октетами следует пробел, после чего передаются аргументы.

    Пример: C: A001 LOGIN <11>
    S: + Ready for additional command text
    C: FRED FOOBAR <7>
    S: + Ready for additional command text
    C: fat man
    S: A001 OK LOGIN completed
    C: A044 BLURDYBLOOP <102856>
    S: A044 BAD No such command as «BLURDYBLOOP»

    7. Пример соединения IMAP 4.1

    Последующее является записью для соединения IMAP 4.1. (Данный пример и нижеприведенное описание синтаксиса практически без изменения взято из документа RFC-2060).

    S: * OK IMAP4rev1 Service Ready
    C: a001 login mrc secret
    S: a001 OK LOGIN completed
    C: a002 select inbox
    S: * 18 EXISTS
    S: * FLAGS (\Answered \Flagged \Deleted \Seen \Draft)
    S: * 2 RECENT
    S: * OK [UNSEEN 17] Message 17 is the first unseen message
    S: * OK [UIDVALIDITY 3857529045] UIDs valid
    S: a002 OK [READ-WRITE] SELECT completed
    C: a003 fetch 12 full
    S: * 12 FETCH (FLAGS (\Seen) INTERNALDATE «17-Jul-1996 02:44:25 -0700»
    RFC822.SIZE 4286 ENVELOPE («Wed, 17 Jul 1996 02:23:25 -0700 (PDT)»
    «IMAP4rev1 WG mtg summary and minutes»
    ((«Terry Gray» NIL «gray» «cac.washington.edu»))
    ((«Terry Gray» NIL «gray» «cac.washington.edu»))
    ((«Terry Gray» NIL «gray» «cac.washington.edu»))
    ((NIL NIL «imap» «cac.washington.edu»))
    ((NIL NIL «minutes» «CNRI.Reston.VA.US»)
    («John Klensin» NIL «KLENSIN» «INFOODS.MIT.EDU»)) NIL NIL
    » «)
    BODY («TEXT» «PLAIN» («CHARSET» «US-ASCII») NIL NIL «7BIT» 3028 92))
    S: a003 OK FETCH completed
    C: a004 fetch 12 body[header]
    S: * 12 FETCH (BODY[HEADER] <350>
    S: Date: Wed, 17 Jul 1996 02:23:25 -0700 (PDT)
    S: From: Terry Gray gray@cac.washington.edu
    S: Subject: IMAP4rev1 WG mtg summary and minutes
    S: To: imap@cac.washington.edu
    S: cc: minutes@CNRI.Reston.VA.US, John Klensin KLENSIN@INFOODS.MIT.EDU
    S: Message-Id: B27397-0100000@cac.washington.edu
    S: MIME-Version: 1.0
    S: Content-Type: TEXT/PLAIN; CHARSET=US-ASCII
    S:
    S: )
    S: a004 OK FETCH completed
    C: a005 store 12 +flags \deleted
    S: * 12 FETCH (FLAGS (\Seen \Deleted))
    S: a005 OK +FLAGS completed
    C: a006 logout
    S: * BYE IMAP4rev1 server terminating connection
    S: a006 OK LOGOUT completed

    8. Формальный синтаксис

    Последующая синтаксическая спецификация использует нотацию Бакуса-Наура (BNF — Backus-Naur Form), как это описано в [RFC-822] с одним исключением, разделителем, используемым в конструкции «#», служит одиночный пробел (SPACE), а не одна или более запятых.

    В случае альтернативных или опционных правил, в которых последующее правило перекрывается с более ранним, более приоритетным считается правило, встретившееся первым. Некоторые, но не все случаи таких правил представлены ниже. Если не указано обратного, все буквенные символы не зависят от использования строчных или прописных букв. Конкретные программные реализации должны воспринимать такие строки при любом написании.

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

    ;; Символьный набор [CHARSET] должен быть зарегистрирован IANA

    search_key ::= «ALL» / «ANSWERED» / «BCC» SPACE astring /
    «BEFORE» SPACE date / «BODY» SPACE astring /
    «CC» SPACE astring / «DELETED» / «FLAGGED» /
    «FROM» SPACE astring /
    «KEYWORD» SPACE flag_keyword / «NEW» / «OLD» /
    «ON» SPACE date / «RECENT» / «SEEN» /
    «SINCE» SPACE date / «SUBJECT» SPACE astring /
    «TEXT» SPACE astring / «TO» SPACE astring /
    «UNANSWERED» / «UNDELETED» / «UNFLAGGED» /
    «UNKEYWORD» SPACE flag_keyword / «UNSEEN» /

    ;; Выше этой строки все в [IMAP2]

    «DRAFT» /
    «HEADER» SPACE header_fld_name SPACE astring /
    «LARGER» SPACE number / «NOT» SPACE search_key /
    «OR» SPACE search_key SPACE search_key /
    «SENTBEFORE» SPACE date / «SENTON» SPACE date /
    «SENTSINCE» SPACE date / «SMALLER» SPACE number /
    «UID» SPACE set / «UNDRAFT» / set /
    «(» 1#search_key «)»
    section ::= «[» [section_text / (nz_number *[«.» nz_number]
    [«.» (section_text / «MIME»)])] «]»
    section_text ::= «HEADER» / «HEADER.FIELDS» [«.NOT»]
    SPACE header_list / «TEXT»
    select ::= «SELECT» SPACE mailbox
    sequence_num ::= nz_number / «*»

    ;; * является наибольшим используемым числом. Для порядковых номеров
    ;; сообщений оно равно количеству сообщений в почтовом ящике.
    ;; Для уникальных идентификаторов оно равно уникальному
    ;; идентификатору последнего сообщения в почтовом ящике./p>

    set ::= sequence_num / (sequence_num «:» sequence_num) /
    (set «,» set)

    ;; Идентифицирует набор сообщений. Для порядковых номеров
    ;; сообщений это последовательность чисел с 1 до числа
    ;; сообщений в почтовом ящике.
    ;; Запятая разграничивает индивидуальные номера, двоеточие
    ;; указывает на диапазон чисел включительно.
    ;; Пример для почтового ящика с 15 сообщениями: 2,4:7,9,12:*
    ;; эквивалентно 2,4,5,6,7,9,12,13,14,15.

    ;; Уникальные идентификаторы используются вместо
    ;; последовательных номеров сообщения.

    ;; В возрастающем порядке
    unsubscribe ::= «UNSUBSCRIBE» SPACE mailbox
    user > x_command ::= «X» atom
    zone ::= («+» / «-«) 4digit

    ;; Число из 4 цифр со знаком hhmm, представляющее часы и минуты к западу от Гринвича
    ;; (Это число отличается от Universal Time). Вычитая временную зону из данного времени, можно получить
    ;; форму UT. Зона Universal Time равна «+0000».

    9. Соображения безопасности

    Протокольные операции IMAP 4.1, включая данные электронной почты, передаются через сеть открытым текстом, если только не согласовано применение конфиденциальных методов обмена посредством команды AUTHENTICATE.

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

    Использование команды LOGIN осуществляет передачу паролей открытым текстом. Этого можно избежать, используя для этого команду AUTHENTICATE.

    Протоколы электронной почты: POP3, IMAP4, SMTP

    В этой статье рассмотрены наиболее часто используемые протоколы электронной почты в Интернете — POP3, IMAP и SMTP. Каждый из них имеет определенную функцию и способ работы. В содержании статьи разъясняется, какая конфигурация лучше всего подходит для конкретных потребностей пользователя при использовании e-mail-клиента. А также раскрывается ответ на вопрос о том, какой протокол поддерживает электронную почту e-mail.

    Что такое POP3?

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

    По умолчанию протокол POP3 работает на двух портах:

    порт 110 — это незашифрованный порт POP3;

    порт 995 — его нужно использовать, если вы хотите безопасно подключиться к POP3.

    Что такое IMAP?

    Протокол доступа к интернет-сообщениям (IMAP) — это протокол получения сообщений электронной почты, используемый для доступа к ней на удаленном веб-сервере от локального клиента. IMAP и POP3 являются двумя наиболее часто используемыми протоколами для получения писем и поддерживаются всеми современными почтовыми клиентами и веб-серверами.

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

    Протокол IMAP работает на двух портах:

    порт 143 — это незашифрованный порт IMAP по умолчанию;

    порт 993 — его необходимо использовать, если вы хотите безопасно подключиться с помощью IMAP.

    Что такое SMTP?

    Протокол Simple Mail Transfer Protocol (SMTP) — это стандартный протокол для отправки электронной почты через Интернет.

    SMTP работает в трех портах:

    порт 25 — это незашифрованный порт SMTP по умолчанию;

    порт 2525 — он открывается на всех серверах SiteGround, если порт 25 фильтруется (например, вашим интернет-провайдером), и вы хотите отправлять незашифрованные электронные письма с помощью SMTP;

    порт 465 — он используется, если вы хотите безопасно отправлять сообщения с помощью SMTP.

    По каким протоколам происходит обмен электронной почтой? Понятия и термины

    Термин «сервер электронной почты» относится к двум серверам, необходимым для отправки и получения писем, то есть к SMTP и POP.

    Сервер входящей почты — это сервер, связанный с вашей учетной записью адреса электронной почты. Для нее не может быть более одного входящего почтового сервера. Для доступа к входящим сообщениям необходим почтовый клиент — программа, которая может получать электронную почту из учетной записи, позволяя пользователю читать, пересылать, удалять и отвечать на сообщения. В зависимости от вашего сервера, вы можете использовать выделенный почтовый клиент (например, Outlook Express) или веб-браузер. Так, Internet Explorer применяют для доступа к учетным записям на основе электронной почты. Письма хранятся на сервере входящей почты до его загрузки. После того, как вы загрузили свою почту с почтового сервера, сделать повторно это будет нельзя. Чтобы успешно загрузить данные, необходимо ввести правильные настройки в электронной почтовой программе. Большинство входящих почтовых серверов используют один из следующих протоколов: IMAP, POP3, HTTP.

    Исходящий почтовый сервер (SMTP)

    Это сервер, используемый только для отправки писем (для переноса их из вашей почтовой клиентской программы в приемник). Большинство исходящих почтовых серверов используют SMTP-протокол (Simple Mail Transfer Protocol) для отправки корреспонденции. В зависимости от ваших сетевых параметров сервер исходящей почты может принадлежать вашему интернет-провайдеру или серверу, на котором вы настраиваете свою учетную запись. В качестве альтернативы вы можете использовать SMTP-сервер на основе подписки, который позволит вам отправлять электронные письма с любой учетной записи. Из-за проблем со спамом большинство исходящих почтовых серверов не позволяют отправлять электронные письма, если вы не вошли в свою сеть. Сервер с открытым ретранслятором позволит вам использовать его для отправки электронных писем, независимо от того, принадлежите ли вы к его сетевой группе или нет.

    Порты электронной почты

    Для сетей порт означает конечную точку логического соединения. Номер порта определяет его тип. Ниже перечислены порты электронной почты по умолчанию:

    безопасный SMTP (SSMTP) — порт 465;

    безопасный IMAP (IMAP4-SSL) — порт 585;

    IMAP4 через SSL (IMAPS) — порт 993;

    Secure POP3 (SSL-POP) — порт 995.

    Протоколы электронной почты: IMAP, POP3, SMTP и HTTP

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

    Протокол IMAP

    IMAP (протокол доступа к интернет-сообщениям) — стандартный протокол для доступа к электронной почте с вашего локального сервера. IMAP — это протокол типа «клиент/сервер», в котором электронная почта получена, и данные сохраняются вашим интернет-сервером. Поскольку для этого требуется только небольшая передача данных, он хорошо работает даже при медленном соединении, например, при подключении с помощью модема. При попытке прочитать конкретное сообщение электронной почты клиент загружает данные с сервера. Вы также можете создавать и управлять папками или почтовыми ящиками на сервере, удалять сообщения.

    Протокол POP3

    Протокол передачи электронной почты POP (Post Office Protocol 3) обеспечивает простой, стандартизированный способ доступа пользователей к почтовым ящикам и загрузки сообщений на их компьютеры.

    При использовании протокола POP все ваши сообщения электронной почты будут загружены с почтового сервера на локальный компьютер. Вы также можете оставить копии своих электронных писем на сервере. Преимущество заключается в том, что после загрузки ваших сообщений вы можете отключить интернет-соединение и прочитать свой e-mail на досуге, не прибегая к дополнительным расходам на связь. С другой стороны, с помощью этого протокола вы получаете и загружаете много нежелательных сообщений (включая спам или вирусы).

    Протокол SMTP

    Протокол SMTP (Simple Mail Transfer Protocol) используется агентом передачи почты (MTA) для доставки электронных сообщений на определенный сервер получателя. SMTP можно использовать только для отправки электронных писем, а не для их получения. В зависимости от настроек вашей сети или интернет-провайдера вы можете использовать SMTP-протокол только в определенных условиях.

    Протоколы HTTP

    HTTP не является протоколом, предназначенным для связи по электронной почте, но его можно использовать для доступа к вашему почтовому ящику. Его также нередко называют веб-электронной почтой. Он может использоваться для составления или получения электронных писем из вашей учетной записи. Hotmail — хороший пример использования HTTP в качестве протокола электронной почты.

    Управляемые передачи файлов и сетевые решения

    Ваша способность отправлять и получать электронную почту в основном обусловлена ​тремя протоколами TCP. Ими являются SMTP, IMAP и POP3.

    Начнем с SMTP, потому что его основная функция отличается от двух других. Протокол SMTP, или Simple Mail Transfer Protocol, в основном используется для отправки электронной почты от почтового клиента (например, Microsoft Outlook, Thunderbird или Apple Mail) на сервер электронной почты. Он также используется для ретрансляции или пересылки почтовых сообщений с одного почтового сервера на другой. Это необходимо в случае, если у отправителя и получателя есть разные поставщики услуг электронной почты.

    SMTP, который указан в RFC 5321, использует порт 25 по умолчанию. Он также может использовать порт 587 и порт 465. Последний, который был представлен как порт выбора для безопасного SMTP (a.k.a. SMTPS), считается устаревшим. Но на самом деле он по-прежнему используется несколькими поставщиками почтовых услуг.

    Протокол почтового отделения, или POP, используется для извлечения сообщений электронной почты с почтового сервера на e-mail-клиент. Последняя версия, которая широко используется, — это версия 3, отсюда и термин «POP3».

    POP, версия 3, указанная в RFC 1939, поддерживает расширения и несколько механизмов аутентификации. Функции проверки подлинности необходимы, чтобы злоумышленники не получали доступ к сообщениям пользователей.

    Клиент POP3 получает электронную почту следующим образом:

    подключается к почтовому серверу на порту 110 (или 995 для соединений SSL/TLS);

    извлекает сообщения электронной почты;

    удаляет копии сообщений, хранящихся на сервере;

    отключается от сервера.

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

    IMAP, особенно текущая версия (IMAP4), является более сложным протоколом. Это позволяет пользователям группировать связанные сообщения и размещать их в папках, которые, в свою очередь, могут быть организованы иерархически. Он также оснащен флагами сообщений, которые указывают, было ли сообщение прочитано, удалено или получено. Он даже позволяет пользователям выполнять поиск по почтовым ящикам сервера.

    Логика работы (настройки imap4):

    подключается к почтовому серверу через порт 143 (или 993 для соединений SSL / TLS);

    извлекает сообщения электронной почты;

    служит для подключения до закрытия приложения почтового клиента и загрузки сообщений по требованию.

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

    Выбор между IMAP и POP3

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

    Если для вас важно место для хранения на сервере, то выбирайте POP3. Сервер с ограниченным объемом памяти является одним из основных факторов, которые могут заставить вас поддержать POP3. Поскольку IMAP оставляет сообщения на сервере, он может потреблять пространство памяти быстрее, чем POP3.

    Если вы хотите получить доступ к почте в любое время, то лучше остановиться на IMAP. Есть одна веская причина, по которой IMAP был предназначен для хранения сообщений на сервере. Он используется для поиска сообщений с нескольких устройств — иногда даже одновременно. Поэтому если у вас есть iPhone, планшет Android, ноутбук и рабочий стол и вы хотите читать электронную почту с любого или всех этих устройств, то IMAP будет лучшим выбором.

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

    Например, если вы читаете сообщения A, B и C, то хотите, чтобы они также были помечены как «прочитанные» на других устройствах. Если вы удалили письма B и C, то захотите, чтобы те же сообщения удалялись из вашего почтового ящика на всех гаджетах. Все эти синхронизации могут быть достигнуты только в том случае, если вы используете IMAP.

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

    Разумеется, все функциональные возможности IMAP имеют свою цену. Эти решения сложнее реализовать, и в конечном итоге протокол потребляет намного больше ЦП и ОЗУ, особенно когда он выполняет процесс синхронизации. Фактически высокая загрузка процессора и памяти может произойти как на стороне клиента, так и на стороне сервера, если есть тонна сообщений для синхронизации. С этой точки зрения протокол POP3 менее затратен, хотя и менее функционален.

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

    Скорость — преимущество, которое варьируется и зависит от ситуации. POP3 имеет возможность загружать все почтовые сообщения при подключении. А IMAP может при необходимости (например, при недостаточном количестве трафика) загружать только заголовки сообщений или определенные части и оставлять вложения на сервере. Только когда пользователь решит, что оставшиеся части стоят загрузки, они станут доступны для него. Поэтому IMAP можно считать более быстрым.

    Однако если все сообщения на сервере должны загружаться каждый раз, то POP3 будет работать гораздо быстрее.

    Как вы можете увидеть, каждый из описываемых протоколов имеет свои преимущества и недостатки. Вам решать, какие функции или возможности важнее.

    Также желаемый способ доступа к e-mail-клиенту определяет предпочтительность протокола. Пользователи, работающие только с одной машины и использующие веб-почту для доступа к своим новым электронным письмам, оценят POP3.

    Однако пользователи, которые обмениваются почтовыми ящиками или получают доступ к своим электронным письмам с разных компьютеров, предпочтут IMAP.

    Спам-брандмауэры с SMTP, IMAP и POP3

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

    Брандмауэры SMTP прозрачны для конечных пользователей; для клиентов нет изменений конфигурации. Пользователи по-прежнему получают и отправляют почтовые сообщения на сервер электронной почты. Так, Exchange или Dominos должны настраивать маршрутизацию сообщений на брандмауэр на основе прокси-сервера при отправке электронной почты, а также обеспечивать возможность отправки писем с брандмауэра.

    ИТ База знаний

    ShareIT — поделись знаниями!

    Полезно

    Узнать IP — адрес компьютера в интернете

    Онлайн генератор устойчивых паролей

    Онлайн калькулятор подсетей

    Калькулятор инсталляции IP — АТС Asterisk

    Руководство администратора FreePBX на русском языке

    Руководство администратора Cisco UCM/CME на русском языке

    Серверные решения

    Телефония

    FreePBX и Asterisk

    Настройка программных телефонов

    Корпоративные сети

    Похожие статьи

    Установка MySQL Server на CentOS 7

    Как работать с регулярными выражениями

    Про операционную систему Cisco IOS

    Виртуализация VMware и HyperV

    Самое интересное про SMTP, POP3 и IMAP

    3 минуты чтения

    Сегодня мы подробно расскажем про наиболее используемые в сети интернет протоколы – POP3, IMAP и SMTP. Каждый из указанных протоколов имеет определенное назначение и функциональные возможности. Давайте попробуем разобраться.

    Протокол POP3 и его порты

    Post Office Protocol 3 (POP3) это стандартный протокол почты созданные для получения электронных писем с удаленного сервера на e-mail клиент.POP3 позволяет вам сохранить почтовое сообщение на ваш компьютер и даже прочесть его, в случае, если вы находитесь не в сети. Важно отметить, что если вы решили использовать POP3 для подключения к учетной записи почты, письма, которые уже скачаны на компьютер, будут удалены с почтового сервера. Как пример, если вы используете несколько компьютеров для подключения к одному почтовому аккаунту, то протокол POP3 может быть не лучшим выбором в данной ситуации. С другой стороны, так как почта хранится локально, на ПК конкретного пользователя, это позволяет оптимизировать дисковое пространство на стороне почтового сервера.

    По умолчанию, протокол POP3 использует следующие порты:

    • Порт 110 – это порт протокола POP3 по умолчанию. Не является безопасным.
    • Порт 995 – этот порт следует использовать в том случае, если вы хотите установить безопасное соединение.

    Протокол IMAP и порты

    Internet Message Access Protocol (IMAP) – это почтовый протокол, созданный для доступа к почте с локального почтового клиента. IMAP и POP3 – наиболее популярные в сети интернет протоколы, используемые для получения e-mail. Оба этих протокола поддерживается всеми современными почтовыми клиентами (MUA — Mail User Agent) и WEB – серверами.

    В то время как POP3 позволяет доступ к почте только с одного приложения, IMAP позволяет доступ из множества клиентов. По этой причине, IMAP наиболее адаптивен в тех случаях, когда доступ к одному почтовому аккаунту необходим для нескольких пользователей.

    По умолчанию, протокол IMAP использует следующие порты:

    • Порт 143 – порт по умолчанию. Не безопасен.
    • Порт 993 – порт для безопасного соединения.
    Протокол SMTP и его порты

    Simple Mail Transfer Protocol (SMTP) – это стандартный протокол для отправки почтовых сообщений по сети интернет.

    Данный протокол описан в RFC 821 и RFC 822, впервые опубликованных в августе 1982 года. В рамках данных RFC, формат адреса должен быть в формате имя_пользователя@доменное_имя. Доставка почты, аналогична работе обычной почтовой службы: например, письмо на адрес ivan_ivanov@merionet.ru, будет интерпретирован так: ivan_ivanov – адрес, а merionet.ru – почтовый индекс. Если доменное имя получателя отличается от доменного имени отправителя, то MSA (Mail Submission Agent) отправит письмо через Mail Transfer Agent (MTA). Главная идея MTA в том, чтобы перенаправлять письма в другую доменную зону, по аналогии, как традиционная почты отправляет письма в другой город или область. MTA так же получает почту от других MTA.

    Протокол SMTP использует следующие порты:

    • Порт 25 – порт SMTP по умолчанию. Не безопасен.
    • Порт 2525 – данный порт используется в том случае, если интернет провайдер фильтрует порт 25.
    • Порт 465 – порт для безопасного соединения.
    • SMTP
    • POP3
    • 4664
    • 28

    Полезна ли Вам эта статья?

    Пожалуйста, расскажите почему?

    Нам жаль, что статья не была полезна для вас :( Пожалуйста, если не затруднит, укажите по какой причине? Мы будем очень благодарны за подробный ответ. Спасибо, что помогаете нам стать лучше!

    Подпишитесь на нашу еженедельную рассылку, и мы будем присылать самые интересные публикации :) Просто оставьте свои данные в форме ниже.

    Компьютерные технологии (архив 2012г.)

    Лекция 6 — Электронная почта. Формат сообщения. Протоколы SMTP, POP3, IMAP4.

    Служба электронная почта — предназначена для обмена сообщениями (письмами).

    Клиент (MS Outlook, The bat . ) готовит («упаковывает») и посылает серверу (почтовое отделение) сообщения, принимает и просматривает сообщения.

    Сервер электронной почты (Sendmail, MS Exchange . ) обрабатывает сообщения (сортирует) и отправляет локальному адресату или удаленному серверу (почтовому отделению).

    Электронная почта во многом похожа на обычную почтовую службу.

    Отправка и получение почты

    SMTP (Simple Mail Transfer Protocol) — простой протокол передачи почты, используется для отправки почты, как клиентом на сервер, так и сервером на другой сервер.

    POP3 (Post Office Protocol) — используется для приема почты клиентом с сервера.

    IMAP 4 (Internet Message Access Protocol) —

    UUCP (Unix-Unix-CoPy) — используется для отправки и приема почты, как клиентом на(с) сервер(а), так и сервером на другой сервер. В данное время почти не используется, поэтому рассматривать не будем.

    Первый стандарт — RFC0724 (Proposed official standard for the format of ARPA Network messages D. Crocker, K.T. Pogran, J. Vittal, D.A. Henderson May-12-1977).

    Последняя версия — RFC2822 (Internet Message Format P. Resnick, Ed. April 2001).

    Текстовая (ASCII) информация может передаваться, как есть.

    Остальная информация должна быть закодирована, т.к. изначально не предполагалось ее передавать. При использовании расширения протокола SMTP — ESMTP (Enhaced SMTP) можно кодировать в 8-битном виде. Это все выполняет почтовая программа.

    base64 — кодирует из набор 00-FFв ASCII, чтобы можно было передавать по SMTP (кодируют бинарные файлы).

    7bit — не кодирует, указывает, что код ASCII.

    8bit — указывает, что не только символы ASCII.

    quoted-printable — используется для кодирования национальных языков, символов второй части таблицы («А» — «=3D»).

    Сообщение состоит из:

    конверта сообщения (информация для доставки и обработки сообщения)

    тела сообщения (данные отправителя)

    В простом случае конверт состоит только из заголовка, который отделен от тела пустой строкой.

    From: // адрес отправителя
    To:

    // адрес получателя
    Subject: С новым годом! // тема сообщения
    Mime-Version: 1.0 // инициализация Mime
    X-Mailer: mPOP Web-Mail 2.19 // тип и версия почтовой программы клиента
    Date: Fri, 19 Sep 2003 08:37:43 +0400 // дата отправки сообщения
    Reply-To: // адрес для ответа
    Content-Type: text/plain; charset=koi8-r // тип и подтип MIME
    Content-Transfer-Encoding: 8bit // идентификатор типа кодировки
    Message-Id: // уникальный идентификатор сообщения

    С новым годом Петя! //Тело сообщения

    Пример простого сообщения

    Received: by dionis.kfti.knc.ru with SMTP; Thu, 10 Oct 2002 16:00:49 +0400 (MSK)
    Message-ID:
    From: «Katia»
    To:
    Cc: «Dima» ,»Lena»
    Subject: С новым годом!
    Date: Thu, 10 Oct 2002 16:08:05 +0400
    Organization: KPhTI
    MIME-Version: 1.0
    Content-Type: text/plain; charset=»koi8-r»
    Content-Transfer-Encoding: 8bit
    X-Priority: 3
    X-MSMail-Priority: Normal
    X-Mailer: Microsoft Outlook Express 5.00.2615.200
    X-MimeOLE: Produced By Microsoft MimeOLE V5.00.2615.200

    Пример заголовка сообщения с отправкой нескольким пользователям (поле Cc:)

    From: dima@dionis.kfti.knc.ru
    To: igor@dionis.kfti.knc.ru
    Subject: С новым годом!
    Received: by nmc.tatarstan.ru; Fri, 06 Dec 2002 13:53:32 +0300 (msk)
    Received: by kabmin.kazan.su; Fri, 06 Dec 2002 13:48:16 +0400 (MSK)
    Received: by nmc.tatarstan.ru; Thu, 05 Dec 2002 18:47:11 +0300 (msk)
    Received: from spider.ts by nmc.tatarstan.ru with SMTP; Thu, 05 Dec 2002 18:37:26 +0300 (msk)
    Received: (qmail 3541 invoked from network); 5 Dec 2002 15:38:24 -0000
    Received: from unknown (HELO mvv) (192.168.103.44) by spider.ts with SMTP; 5 Dec 2002 15:38:21 -0000
    Organization: Techoserv A/S
    X-Priority: 3
    X-MSMail-Priority: Normal
    X-Mailer: Dipost Crypto (v2.50C)
    X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2600.0000
    X-Copy-From: gena@kabmin.tatarstan.ru
    Mime-Version: 1.0
    Content-Type: multipart/mixed; boundary=»—Factor Dimail—«

    Пример заголовка сообщения с промежуточными серверами (поле — Received:)

    X-DIONIS-Forwarded: by

  • to at Tue, 22 Feb 2000 14:42:05 +0300 (MSK)
    Received: by nmc.tatarstan.ru; Tue, 22 Feb 2000 14:41:51 +0400 (msk)
    Received: from ben.irex.ru by nmc.tatarstan.ru with SMTP; Tue, 22 Feb 2000 14:34:01 +0400 (msk)
    Received: from unknown ([195.178.196.156])
    by ben.irex.ru (8.9.3/8.9.1) with SMTP id NAA25654;
    Tue, 22 Feb 2000 13:29:41 +0300
    Message-ID:
    From: «Jakubson Olga»
    To:
    Cc: , , ,
    ,
  • , ,

    Пример заголовка сообщения с прикрепленными файлами (FileName).

    —BANNERBANK_280830843726477
    Content-Type: text/plain; charset=koi8-r
    Content-Transfer-Encoding: 8bit

    Посылаю файл wget.tgz

    —BANNERBANK_280830843726477
    Content-Type: application/octet-stream; name=»wget.tgz»
    Content-Transfer-Encoding: base64
    Content-Disposition: attachment;
    filename=»wget.tgz»

    H4sICHc5pzYAA3dnZXQxNTMudGFyAOw8a1PbyLL7NfoVfSC1GAoZm+eGbLYg
    PBJXwFDYSTZ1zqlkLI3tucga7WiE8X44v/1290iybCBx2GzOrbpxbYwlzXT3
    9Lt7RjseSOs36zv1rY2f/q4PbDf2dnYA/+41t/fwL36am+6v+zQAdncbzZ3G
    .
    .
    .
    vUav0Wv0Gr1Gr9Fr9Hr61/8PvGbSyABoGgA=

    Пример заголовка сообщения с прикрепленным файлом

    Некоторые поля заголовка:

    From — адреса отправителей.

    Sender — адрес реального отправителя.
    Пример:
    From: vasy@mail.ru
    pety@mail.ru
    Sender: misha@mail.ru

    To — адрес получателя.

    Cc — адреса получателей копий сообщений.
    Пример:
    To: vasy@mail.ru
    pety@mail.ru
    Cc: misha@mail.ru, katy@mail.ru

    Date — дата отправки сообщения.

    Subject — тема сообщения.

    Message-ID — уникальный идентификатор сообщения.

    Reply-To — адрес для ответа.

    Received — адреса и время обработки сообщения промежуточным сервером.

    X-Mailer — тип и версия почтовой программы клиента.

    Organization — название организации отправителя

    MIME-Version — поле для идентификации стандарта MIME, значит письмо использует MIME.

    Content-Type — тип и подтип MIME (text/html,audio/midi).

    Content-Transfer-Encoding — идентификатор типа кодировки (base64, quoted-printable, 7bit, 8bit, binary и т.д.).

    base64 — кодирует из набор 00-FFв ASCII, чтобы можно было передавать по SMTP (кодируют бинарные файлы).

    7bit — не кодирует, указывает что код ASCII.

    8bit — указывает, что не только символы ASCII.

    quoted-printable — используется для кодирования национальных языков, символов второй части таблицы («А» — «=3D»).

    Первый стандарт — RFC0788 (Simple Mail Transfer Protocol J. Postel Nov-01-1981).

    Последняя версия — RFC2821 (Simple Mail Transfer Protocol J. Klensin, Ed. April 2001).

    Simple Mail Transfer Protocol — протокол высокого уровня (а именно, уровня приложений), используется для отправки почты, как клиентом на сервер, так и сервером на другой сервер.

    Порт по умолчанию — 25.

    Основной недостаток протокола, это отсутствие аутентификации и «докачки» (как в FTP, HTTP) сообщений, т.е. если вы посылаете большое письмо (10Мбайт), то в случае разрыва соединения ваше сообщение придется передавать заново, и возможно так до бесконечности. Поэтому большие письма необходимо резать на части.

    События работы SMTP протокола:

    Клиент инициирует соединение с сервером

    Клиент посылает запросы на обслуживание

    Сервер отвечает на эти запросы

    Модель протокола SMTP

    Последовательность команд SMTP

    Протокол SMTP оговаривает последовательность SMTP-команд

    Некий Vasy абонент сервера kstu.ru, посылает письма трем абонентам сервера kazan.ru (Pety, Koly, Dima) одно письмо.

    Рассмотрим листинг передачи сервера kstu.ru серверу kazan.ru:

    R — сервер (receive)

    R 220 kazan.ru Simple Mail Transfer Service Ready // код ответа 220 (соединение установлено), сервер kstu.ru, протокол SMTP
    S HELO kstu.ru // Соединение установлено, «Я kstu.ru», идентификация производится по kstu.ru
    R 250 kazan.ru // команда принята и обработана, идентификация прошла
    S MAIL FROM: // Начало почтовой транзакции, обратный адрес Vasy@kstu.ru.
    R 250 OK // Сервер согласен принять сообщение от Vasy@kstu.ru
    S RCPT TO:

    // Кому отправить письмо, Pety@kazan.ru
    R 250 OK // Сервер согласен принять сообщение для Pety@kazan.ru
    S RCPT TO: // Еще кому отправить письмо, Koly@kazan.ru
    R 550 No such user here // Сервер выдает ошибку 550, сообщая, что такого пользователя нет
    S RCPT TO: // Еще кому отправить письмо, Dima@kazan.ru
    R 250 OK // Сервер согласен принять сообщение для Dima@kazan.ru
    S DATA // Запрос на передачу данных
    R 354 Start mail input; end with . // Разрешение передачи данных, последняя строка должна содержать «точку»
    S From: //Текст сообщения (включая заголовок).
    S To:


    S Subject: С новым годом!
    S Mime-Version: 1.0
    S X-Mailer: mPOP Web-Mail 2.19
    S Date: Fri, 19 Sep 2003 08:37:43 +0400
    S Reply-To:
    S Content-Type: text/plain; charset=koi8-r
    S Content-Transfer-Encoding: 8bit
    S Message-Id:
    S
    S С новым годом Петя!
    S . // Конец сообщения, клиент послал точку
    R 250 OK // Сервер получил данные
    S QUIT // Клиент делает запрос на закрытие соединения
    R 221 kazan.ru Service closing transmission channel // Сервер закрывает соединение

    Некоторые команды SMTP

    Обязательные команды (команды которые должны присутствовать всегда)

    HELO — Открытие сеанса связи (hello).

    MAIL — Начинает почтовую транзакцию, которая завершается передачей данных в один или несколько почтовых ящиков (mail).

    RCPT — Идентифицирует получателя почтового сообщения (recipient).

    DATA — Строки, следующие за этой командой, рассматриваются получателем как данные почтового сообщения. В случае SMTP, почтовое сообщение заканчивается комбинацией символов: CRLF-точка-CRLF.

    RSET — Прерывает текущую почтовую транзакцию (reset).

    NOOP — Требует от получателя не предпринимать никаких действий, а только выдать ответ ОК. Используется главным образом для тестирования.(No operation).

    QUIT — Закрытие сеанса связи.

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

    SEND — Начинает почтовую транзакцию, доставляющую данные на один или несколько терминалов (а не в почтовый ящик).

    SOML — Начинает транзакцию MAIL или SEND, доставляющую данные на один или несколько терминалов или в почтовые ящики.

    SAML — Начинает транзакцию MAIL и SEND, доставляющие данные на один или несколько терминалов и в почтовые ящики.

    EXPN — Команда SMTP-приемнику подтвердить, действительно ли аргумент является адресом почтовой рассылки и если да, вернуть адрес получателя сообщения (expand).

    HELP — Команда SMTP-приемнику вернуть сообщение-справку о его командах.

    TURN — Команда SMTP-приемнику либо сказать ОК и поменяться ролями, то есть стать STMP- передатчиком, либо послать сообщение-отказ и остаться в роли SMTP-приемника.

    Синтаксис некоторых команд SMTP

    Команды, MAIL, SEND, SOML и SAML, имеют одинаковый синтаксис:

    (обратный адрес) указывает серверу, кому в случае ошибки отослать сообщение.

    (CRLF) возврат каретки.

    Примечание: Команды SEND, SOML и SAML дополнительны и используются довольно редко.

    Синтаксис RCPT похож на синтаксис команды MAIL:

    Однако, в отличие от MAIL, аргумент RCPT начинается со слова .

    Некоторые коды ответов SMTP

    Каждая цифра в коде ответа имеет определенный смысл. Первая цифра означает, было ли выполнение команды успешно (2), неуспешно (5) или еще не закончилось (3). Как указано в приложении Е документа RFC 821, простой SMTP-клиент может анализировать только первую цифру в ответе сервера, и на основании ее продолжать свои действия. Вторая и третья цифры кода ответа разъясняют значение первой. Если вы разрабатываете SMTP-приложение, обязательно изучите конструкцию всех кодов SMTP-ответа.

    211 Ответ о состоянии системы или помощь
    214 Сообщение-подсказка (помощь)
    220 служба готова к работе
    221 служба закрывает канал связи
    250 Запрошенное действие почтовой транзакции успешно завершилось
    251 Данный адресат не является местным; сообщение будет передано по маршруту
    354 Начинай передачу сообщения. Сообщение заканчивается комбинацией CRLF-точка-CRLF
    421 служба недоступна; соединение закрывается
    450 Запрошенная команда почтовой транзакции не выполнена, так как почтовый ящик недоступен
    451 Запрошенная команда не выполнена; произошла локальная ошибка при обработке сообщения
    452 Запрошенная команда не выполнена; системе не хватило ресурсов
    500 Синтаксическая ошибка в тексте команды; команда не опознана
    501 Синтаксическая ошибка в аргументах или параметрах команды
    502 Данная команда не реализована
    503 Неверная последовательность команд
    504 У данной команды не может быть аргументов
    550 Запрошенная команда не выполнена, так как почтовый ящик недоступен
    551 Данный адресат не является местным; попробуйте передать сообщение по маршруту
    552 Запрошенная команда почтовой транзакции прервана; дисковое пространство, доступное системе, переполнилось
    553 Запрошенная команда не выполнена; указано недопустимое имя почтового ящика
    554 Транзакция не выполнена

    Можно использовать промежуточные сервера для доставки почты получателю.

    передадим сообщение от Vasy@ksu.ru через хосты @kstu.ru, @mail.ru получателю Koly@kazan.ru

    сообщение передается хосту @kstu.ru
    S MAIL FROM:
    S RCPT TO:

    сообщение передается хосту @mail.ru
    S MAIL FROM:
    S RCPT TO:

    ообщение передается хосту kazan.ru
    S MAIL FROM:
    S RCPT TO:

    При этом параметры To, From и Cc остаются без изменений.

    Резервные почтовые серверы (relay)

    В случае если основой сервер не доступен, почта может быть отправлена на резервный, который задается в записях MX (DNS). Резервный сервер хранит почту (клиент ее получить не может) до тех пор, пока не заработает основной сервер, как только основной заработает, резервный передает всю накопившеюся почту. Резервных серверов может быть достаточно много. Как правила несколько разных серверов являются резервными по отношению к друг другу.

    Когда основной сервер не доступен, почта передается на резервный,
    когда основной сервер становится доступен, резервный передает почту основному.

    Отправка сообщения на SMTP с помощью Telnet

    Отправим письмо через Telnet.

    Клиенту необходимо ввести следующие строки:

    HELO
    MAIL FROM:
    RCPT TO:


      DATA
      DATE: 27-Oct-2003 12:48:32
      FROM: Влад Богомолов
      SUBJECT: С новым годом!
      To:

    Подключение и отправка письма telnet’ом (UNIX) на сервер SMTP (Дионис)

    Подключение и отправка письма telnet’ом (Windows) к серверу SMTP (Дионис)

    Подключение и отправка письма telnet’ом (UNIX) к серверу SMTP-Sendmail 8.12.8 (UNIX)

    Post Office Protocol (POP) — протокол доставки почты пользователю из почтового его ящика своего почтового сервера РОР. Когда почта пришла на сервер (по SMTP), она раскладывается по почтовым ящикам. Чтобы забрать почту из ящика нужен POP.

    Первый стандарт РОРЗ определен в RFC 1225 (Post Office Protocol-Version 3, J. Myers, M. Rose November 1994).

    Последняя версия RFC1939 (J. Myers, M. Rose May 1996 )

    Порт по умолчанию — 110.

    Пользователь может получить доступ к РОР-серверу из любой точки доступа к Интернет.

    Модель протокола POP3

    Модель протокола POP

    Принцип работы POP

    В протоколе РОРЗ оговорены три стадии процесса получения почты:

    обновление (завершение транзакции)

    После того как сервер и клиент РОРЗ установили соединение, начинается стадия авторизации. На стадии авторизации клиент идентифицирует себя для сервера. Если авторизация прошла успешно, сервер открывает почтовый ящик клиента и начинается стадия транзакции. В ней клиент либо запрашивает у сервера информацию (например, список почтовых сообщений), либо просит его совершить определенное действие (например, выдать почтовое сообщение). Наконец, на стадии обновления сеанс связи заканчивается.

    Ответ сервера может иметь два значения:

    +OK — положительный ответ

    Если сервер содержит несколько строк, то последняя строка должна содержать «точку».

    USER — имя пользователя, оно является и идентификатором почтового ящика.

    PASS — пароль пользователя

    APOP — авторизация цифровой подписью (используется редко).

    C: USER Pety // Пользователь сообщает свое имя, оно является идентификатором почтового ящика
    S: +ОК // Сервер сообщает, что все в порядке
    C: PASS Petypasw // Пользователь сообщает свой пароль
    S: +ОК Pety’s maildrop has 2 messages (320 octets) // Сервер сообщает, в почтовом ящике Pety есть 2 сообщения

    Пример неудачной авторизации:

    C: USER Pety
    S: -ERR sorry, no mailbox for Pety here

    Пример авторизации с цифровой подписью:

    C: APOP Pety K3u7yG4TfR7gE55DD4ry6G4F // Имя и шифрованный пароль
    S: +ОК Pety’s maildrop has 2 messages (320 octets)

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

    Команда STAT (просмотр ящика) возвращает количество сообщений и общее количество байтов в сообщениях:

    C: STAT
    S: +ОК 2 320 // 2 сообщения, общий размер 320 байт

    Команда LIST (без параметра) возвращает список сообщений в почтовом ящике и их размеры:

    C: LIST
    S: +ОК 2 messages (320 octets)
    S: 1 120 // 1 сообщение, размер 120 байт
    S: 2 200 // 2 сообщение, размер 200 байт
    S: .

    Команда LIST с параметром (номер сообщения) возвращает информацию о заданном сообщении:

    C: LIST 2
    S: +ОК 2 200 .
    C: LIST 3 // запрос несуществующего сообщения
    S: -ERR no such message, only 2 messages in maildrop // сообщение 3 отсутствует

    Команда TOP возвращает заголовок, пустую строку и первые n строк тела сообщения:

    C: TOP 1 10
    S: +ОК
    S: С новым годом
    S:
    S:
    S: .

    Команда NOOP — проверка соединения:

    Команда RETR извлекает сообщение с указанным номером и помещает его в буфер местного UA:

    C: RETR 1
    S: +OK 120 octets
    S: // РОРЗ-сервер высылает сообщение целиком
    S: . // «Точка» — конец сообщения

    Команда DELE отмечает сообщение, которое нужно удалить:

    C: DELE 1
    S: +OK message 1 deleted // сообщение 1 удалено
    C: DELE 2
    S: -ERR message 2 already deleted // сообщение 2 уже удалено

    Команда RSET снимает метки удаления со всех отмеченных ранее сообщений:

    C: RSET
    S: +OK maildrop has 2 messages (320 octets) // в почтовом ящике 2 сообщения были на удаление

    Команда QUIT — переход в режим обновление (UPDATE):

    C: QUIT
    S: +OK dewey POP3 server signing off

    C: QUIT
    S: +OK dewey POP3 server signing off (maildrop empty)

    C: QUIT
    S: +OK dewey POP3 server signing off (2 messages left)

    Обратите внимание на то, что отмеченные для удаления сообщения на самом деле не удаляются до тех пор, пока не выдана команда QUIT и не началась стадия обновления. В любой момент в течение сеанса клиент имеет возможность выдать команду RSET, и все отмеченные для удаления сообщения будут восстановлены.

    Происходит завершение транзакции. И удаление все помеченных сообщений.

    Пример работы POP3

    S:
    C:
    S: +OK POP3 server ready // приветствие сервера
    C: USER Pety
    S: +ОК
    C: PASS Petypasw
    S: +ОК Pety’s maildrop has 2 messages (320 octets)
    C: STAT
    S: +ОК 2 320
    C: LIST
    S: +ОК 2 messages (320 octets)
    S: 1 120
    S: 2 200
    S: .
    C: RETR 1
    S: +OK 120 octets
    S:
    S: .
    C: DELE 1
    S: +OK message 1 deleted
    C: RETR 2
    S: +OK 200 octets
    S:
    S: .
    C: DELE 2
    S: +OK message 2 deleted
    C: QUIT
    S: +OK dewey POP3 server signing off (maildrop empty)
    C:
    S:

    Просмотр сообщений на POP3 сервере с помощью Telnet

    Получим письмо через Telnet.

    Клиенту необходимо ввести следующие строки:

    Подключение и получение письма telnet’ом (UNIX) с сервера POP (Дионис)

    Протокол IMAP4 (Internet Message Access Protocol) позволяет клиентам получать доступ и манипулировать сообщениями электронной почты на сервере. Был разработан для замены POP3.

    Порт по умолчанию — 143.

    В отличии от POP3 позволяет клиенту манипулировать сообщениями на сервере.

    Первый предложенный стандарт — RFC1730 (J. Myers December 1994)

    Последний предложенный стандарт — RFC3501 (VERSION 4rev1 M. Crispin March 2003)

    IMAP, как стандарт, пока не принят, он остается «предложенным стандартом».

    Принцип работы IMAP

    Каждая команда клиента начинается с идентификатора или тега команды, состоящую из букв и цифр, (например, А0001,А0002 и т. д.). Тег является уникальным идентификатором данной команды клиента. Ответы сервера или следующие команды клиента могут ссылаться на данную команду по ее тегу.

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

    Взаимодействие клиента сервером не строится по принципу «запрос-ответ«. Клиент может отправить новую команду на сервера не дожидаясь ответа на предыдущую.

    UID — уникальный идентификатор, присваивается каждому сообщению (не может меняться), 32 бита.

    UIDVALIDITY — уникальный временный идентификатор в данной сессии

    Порядковый номер — имеет каждое сообщение (может меняться).

    Флаги:
    «\Seen» — обозначает, что данное сообщение было прочитано
    «\Answered» — на сообщение был дан ответ
    «\Deleted» — сообщение помечено на удаление
    «\Draft» — формирование данного сообщения еще не завершено
    «\Recent» — сообщение «только что» поступило в почтовый ящик, т. е. данная сессия — первая, которая может прочитать это сообщение.

    Некоторые команды IMAP

    Аргументом команды является строка с идентификатором (именем) и паролем клиента:

    S: * OK IMAP4 revl Service Ready
    С: a001 login Vasy pasword // посылка имени и пароля
    S: a001OK LOGIN completed // идентификация прошла успешно

    Команда LOGIN передает пароль и идентификатор пользователя по сети в открытом виде. Если пользователю необходима защита информации своей почты, он может пользоваться командой AUTHENTICATE. Например, при использовании механизма шифрования KERBEROS, аутентификация выглядит следующим образом:

    S: * OK KerberosV4 IMAP4revl Server
    С: А001 AUTHENTICATE KERBEROS_V4
    S: + AmFYig==
    C: BAcAQrJ5EUkVXLkNNVS5FRFUAOCAsho84kLN3/IJmrMG+25a4DT
    +nZIiriJjnTNHJUtxAA+oOKPKfHEcAFs9a3CL50ebe/ydHJUwYFd
    WwuQlMWiy6IesKvjL5rL9WjXUb9MwT9bpObYLGOKilQh
    S: + or//EoAADZI=
    C: DiAF5MgA+oOIALuBkAAmw==
    S: A001 OK Kerberos V4 authentication successful

    После регистрации в системе клиент должен выбрать каталог (папку) сообщений, с которым он будет работать. Выбор каталога осуществляется командой SELECT. Аргументом команды является имя почтового каталога:

    С: А142 SELECT INBOX // открытие каталога INBOX
    S: * 172 EXISTS // В папке «INBOX» — 172 сообщения
    S: * 1 RECENT // Из них одно только что поступившее
    S: * OK [UNSEEN 12) Message 12 is first unseen // В папке есть непрочитанные сообщения, минимальный порядковый номер непрочитанного сообщения — 12
    S: * OK [UIDVALIDITY 3857529045] UIDs valid // Уникальный временный идентификатор папки INBOX в данной сессии — 3857529045
    S: * FLAGS (\Answered \Flagged \Deleted \Seen \Draft) // Сообщения в данной папке могут иметь флаги, указанные в строке FLAGS
    S: * OK [PERMANENTFLAGS (\Deleted \Seen \*)] Limited // Клиент может менять у сообщений флаги «\Deleted» и «\Seen»
    S: A142 OK [READ-WRITE] SELECT completed // Клиент имеет права на запись и чтение сообщений из INBOX

    Если пользователю необходимо получить информацию о состоянии какого-либо каталога, достаточно воспользоваться командой EXAMINE с именем каталога в качестве аргумента команды, например:

    С: А932 EXAMINE bloop
    S: * 17 EXISTS
    .

    Команда EXAMINE возвращает те же параметры, что и команда SELECT, а отличается от команды SELECT только тем, что открывает заданный почтовый ящик исключительно на чтение.

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

    С: A042 STATUS blob (MESSAGES UNSEEN)
    S: * STATUS blob (MESSAGES 231 UNSEEN 12)
    S: A042 OK STATUS completed

    Чтобы получить список папок (подкаталогов), находящихся в определенной папке и доступных клиенту, можно воспользоваться командой LIST. Аргументами команды являются: имя каталога, список подкаталогов который хотим получить (пустая строка — «» означает текущий каталог) и маска имен подкаталогов. Имена каталогов и маски имен подкаталогов могут интерпретироваться по-разному, в зависимости от реализации почтовой системы и структуры описания иерархии папок. Например, список папок, находящихся в корне, можно получить так:

    С: А004 LIST «/» *
    S: * LIST (\Noinferiors ) «/» INBOX
    S: * LIST

    Ответ сервера содержит список папок в соответствии с их положением в иерархии и флаги данных папок (флаг «\Noinferiors» означает, что внутри данной папки нет, и не может быть построена иерархия).

    После получения информации на каталог, пользователь может прочитать любое сообщение или определенную группу сообщении, часть сообщения или определенные атрибуты сообщения. Для этого используется команда FETCH. Аргументами данной команды являются порядковый номер сообщения и критерии запроса. Критерии содержат описание вида возвращаемой информации. Например, можно запросить части заголовков или UID-сообщений в папке, или сообщения, имеющие или не имеющие определенные флаги. Так запрос заголовков сообщений, находящихся в INBOX с порядковыми номерами от 10 до 12, будет выглядеть так:

    С: А654 FETCH 10:12 BODY [HEADER]
    S: * 10 FETCH BODY [HEADER] <350>
    S: Date: Wed, 17 Jul 1996 02:23:25 -0700 (PDTl
    S: From: raan@globe.com
    S: Subject: Hi
    S: To: imap@world.edu
    S: Message-Id:
    S^ mime-Vresion: 1.0
    S: Content-Type: TEXT/PLAIN; CHARSET=US-ASCII
    S:
    S: )
    S: * 11 FETCH .
    S: * 12 FETCH .
    S: A654 OK FETCH completed

    После просмотра сообщения, пользователь может сохранить его с другими флагами, добавить или удалить флаги сообщения ( пометить данное сообщение на удаление). Для этого используется команда STORE. Аргументами команды являются: номера сообщений, идентификатор операции и перечень флагов. Например, операция добавления флага удаления («\Dеleted») трем сообщениям выглядит следующим образом:

    С: АОО3 SТОRЕ 2:4 +FLAGS (\DELETED)
    S: * 2 FETCH FLAGS (\Deleted \ Seen)
    S: * 3 FETCH FLAGS (\Deleted )
    S: * 4 FETCH FLAGS (\Deleted \Flagged \Seen)
    S: A003 OK STORE completed

    Ответом на выполнение команды будут переданы строки новых флагов указанных сообщений.

    Пользователь также может организовать поиск сообщений по определенным критериям. Для этого используется команда SEARCH. Например, поиск всех непрочитанных сообщений, поступивших от «smith» с 1-03-96 будет выглядеть так:

    C: A282 SEARCH UNSEEN FROM ‘Smith» SINCE 1-Mar-1996
    S: * SEARCH 2 84 882
    S: A282 OK SEARCH completed

    Результатом поиска будут сообщения с последовательными номерами 2, 84 и 882.

    IMAP4 позволяет не только искать и читать сообщения в каталогах, этот протокол позволяет добавлять, копировать и перемещать сообщения в каталоги. Добавление сообщения в папку можно осуществить командой APPEND:

    C: A003 APPENDSAVED-MESSAGES (\Seen) <310>
    C: Date: Mon, 7 Feb 1997 21:52:25 — 0800
    C: From: Fred Foobar
    C: Subject: aftenoon meeteng
    C: TO: mooch@owatagu.siam.edu
    C: Message-Id:
    C: Mime-Version: 1.0
    C: Content-Type: Text/PLAIN; CHARSET=US-ASCII
    C:
    C: Hello Joe, do you think we can meet at 3:30 tomorrow?
    C:
    S: A003 OK APPEND completed

    Команда COPY копирует сообщения с заданными порядковыми номерами в указанный каталог, например:

    C: A003 COPY 2:4 MEETENG
    S: A003 OK COPY completed

    Пример работы IMAP4

    S: * OK IMAP4 revl Service Ready
    С: a001 login Vasy pasword
    S: a001OK LOGIN completed
    С: a002 SELECT INBOX
    S: * 18 EXISTS
    S: * 2 RECENT
    S: * OK [UNSEEN 17) Message 17 is first unseen
    S: * OK [UIDVALIDITY 3857529045] UIDs valid
    S: * FLAGS (\Answered \Flagged \Deleted \Seen \Draft)
    S: a002 OK [READ-WRITE] SELECT completed
    С: a003 FETCH 10:12 BODY [HEADER]
    S: * 12 FETCH BODY [HEADER] <350>
    S: Date: Wed, 17 Jul 1996 02:23:25 -0700 (PDTl
    S: From: raan@globe.com
    S: Subject: Hi
    S: To: imap@world.edu
    S: Message-Id:
    S^ mime-Vresion: 1.0
    S: Content-Type: TEXT/PLAIN; CHARSET=US-ASCII
    S:
    S: )
    S: a003 OK FETCH completed
    С: a004 SТОRЕ 12 +FLAGS (\DELETED)
    S: * 12 FETCH FLAGS (\Deleted \ Seen)
    S: A003 OK STORE completed
    C: a005 logout
    S: * BYE IMAP4rev1 server terminating connection
    S: a005 OK LOGOUT completed

    Просмотр сообщений на IMAP4 сервере с помощью Telnet

    Получим письмо через Telnet.

    Клиенту необходимо ввести следующие строки:

    a001 login bogomolov ***********
    a002 select inbox
    a004 fetch 1 rfc822.header

    Подключение и получение заголовка письма telnet’ом (UNIX) с сервера IMAP4 (Дионис)

    Национальная библиотека им. Н. Э. Баумана
    Bauman National Library

    Персональные инструменты

    IMAP (Internet Message Access Protocol)

    IMAP
    Международный стандарт: Internet Message Access Protocol
    Уровень (по модели OSI): Прикладной
    Семейство: стек протоколов TCP/IP
    Порт/ID: 143/TCP, 993/TCP (IMAP over SSL)
    Назначение протокола: Доступ к почтовым ящикам
    Спецификация: RFC 3501
    Основные реализации (клиенты): MUA (Outlook Express, Opera, Mozilla Thunderbird, The Bat!, Claws Mail, mutt)
    Основные реализации (серверы): UW IMAP,
    Courier,
    Cyrus,
    Dovecot
    Вступил в силу с: 1986

    IMAP (англ. Internet Message Access Protocol ) — протокол прикладного уровня для доступа к электронной почте. Базируется на транспортном протоколе TCP и использует порт 143. IMAP предоставляет пользователю обширные возможности для работы с почтовыми ящиками, находящимися на центральном сервере. Почтовая программа, использующая этот протокол, получает доступ к хранилищу корреспонденции на сервере так, как будто эта корреспонденция расположена на компьютере получателя. Электронными письмами можно манипулировать с компьютера пользователя (клиента) без постоянной пересылки с сервера и обратно файлов с полным содержанием писем.

    Для отправки писем используется обычно протокол SMTP, так как собственная команда отправки протокола IMAP, называемая APPEND, считается «неудачной» и «небезопасной».

    Содержание

    Область применения

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

    Версии IMAP

    • Original IMAP
    • IMAP2
    • IMAP3
    • IMAP2bis
    • IMAP4
    • IMAP4rev1

    Преимущества IMAP над POP3

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

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

    Благодаря системе флагов, определенной в IMAP4, клиент может отслеживать состояние сообщения (прочитано, отправлен ответ, удалено и т. д.); данные о флагах хранятся на сервере. Клиенты IMAP4 могут создавать, переименовывать и удалять ящики и перемещать сообщения между ящиками. Кроме того, можно использовать расширение IMAP4 Access Control List для управления правами доступа к ящикам.

    Поиск сообщений происходит на стороне сервера. IMAP4 имеет явный механизм расширения.

    Недостатки IMAP

    Множественный доступ к почтовым ящикам связан с рядом проблем, особенно, если информация в ящиках доступна для записи.

    Хотя программное обеспечение, реализующее протокол IMAP , постоянно совершенствуется, IMAP менее защищен, чем POP3. Возможность хранить сообщения на сервере может стать причиной злоупотреблений со стороны пользователей, которые будут переполнять хранилище сообщений ненужной информацией.

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

    Большие возможности, предоставляемые протоколом IMAP , создают большие сложности при разработке, настройке и эксплуатации серверов и клиентов.

    Общие сведения

    Допускается иерархическое расположение почтовых ящиков в каталогах и их подкаталогах, причем имена каталогов и почтовых ящиков сами по себе не различаются. Почтовый ящик может быть только конечным элементом иерархической структуры, он не может содержать никаких нижестоящих элементов. Каталог может содержать подкаталоги и почтовые ящики, но он не содержит сообщений и не может быть выбран командой SELECT .

    Символ, используемый в качестве иерархического разделителя, может различаться в зависимости от используемого на сервере программного обеспечения. Обычно это косая черта: / , если сервер работает под управлением операционной системы, совместимой с UNIX , обратная косая черта: \ для операционной системы Windows и точка для имен групп новостей USENET.

    Допускается использование различных пространств имен почтовых ящиков и, соответственно, разных иерархических разделителей. Например, если сервер IMAP предоставляет доступ к ящикам, расположенным в каталогах файловой системы UNIX и к группам новостей USENET , то в первом случае в качестве иерархического разделителя используется косая черта, а во втором – точка. Чтобы использовать и различать разные пространства имен на одном сервере IMAP , имена, принадлежащие каждому из используемых пространств, должны начинаться с некоторого префикса, обычно начинающегося символом «#». Естественно, запросы, в которых путь к ящику начинается с одного префикса, будут давать отличные результаты от таких же запросов, начинающихся с другого префикса. Используемое по умолчанию пространство имен может префикса не иметь.

    Клиент может выяснить, какие именно пространства имен для почтовых ящиков каких типов поддерживаются данным сервером IMAP , если сервер поддерживает расширение NAMESPACE. Префикс и иерархический разделитель конкретного имени почтового ящика или каталога можно выяснить при помощи команды LIST.

    Состояния сервера

    Сервер IMAP ожидает соединения от клиентов на порту TCP 143. После установления соединения сервер посылает свое приветствие клиенту, и начинается диалог, в котором клиент посылает серверу команды, а сервер сообщает о результатах их выполнения или присылает затребованную клиентом информацию. Как и сеанс POP3, сеанс IMAP делится на несколько состояний ( states ). Допустимый набор команд зависит от текущего состояния сеанса. Сеанс может находиться в одном из следующих состояний:

    • Неаутентифицированное состояние
    • Аутентифицированное состояние
    • Выбранное состояние
    • Состояние выхода
    1. Соединение без предварительной аутентификации
    2. Соединение с предварительной аутентификацией
    3. Отвергнутое соединение
    4. Успешная аутентификация
    5. Успешное выполнение команды SELECT или EXAMINE
    6. Команда CLOSE или неудачное завершение команды SELECT или EXAMINE
    7. Команда LOGOUT или потеря связи

    Команды протокола IMAP

    Команды клиента и ответы сервера IMAP

    Команда клиента состоит из идентификатора (ярлыка) – короткой строкой, состоящей из букв и цифр, не повторяющейся в других командах в течение всего сеанса. За ярлыком следует сама команда и ее аргументы. Регистр символов в названиях команд, как и в большинстве аргументов, как правило, не имеет значения.

    Кроме стандартных команд, которые обязательно должны поддерживаться, имеются также дополнительные команды, описанные в стандартах и поддерживаемые серверами IMAP как элементы расширений. Разработчики также могут добавлять в своих реализациях новые команды. Названия таких нестандартизированных команд должны начинаться с буквы Х. Имена стандартных команд с буквы Х начинаться не могут.

    Все ответы сервера начинаются с метки, после которой следует отделенный пробелом текст.

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

    • OK (успешное выполнение)
    • NO (невыполнение)
    • BAD (ошибка в команде)

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

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

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

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

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

    Сервер может передавать литерал, не дожидаясь разрешения клиента, клиент, прежде чем передавать литерал, должен дождаться разрешения – строки, начинающейся с метки «+». Например:

    Команды, допустимые при любом состоянии сеанса IMAP

    CAPABILITY

    В ответ на эту команду сервер присылает непомеченную строку с ключевым словом CAPABILITY, содержащую список поддерживаемых возможностей (расширений) и их параметров. В число возможностей входит в частности поддерживаемая версия протокола IMAP – IMAP4rev1 и механизмы аутентификации. Возможности IMAP описываются в различных RFC или могут вводиться разработчиками. В последнем случае их названия должны начинаться с буквы Х. Названия стандартных возможностей с этой буквы начинаться не могут.

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

    LOGOUT

    Команды неаутентифицированного состояния

    Клиент должен успешно аутентифицироваться, чтобы перейти в следующее состояние. Алгоритмы аутентификации для протокола IMAP не отличаются принципиально от рассматривавшихся в предыдущих главах алгоритмов аутентификации для протоколов SMTP и POP3.

    Серверы IMAP могут допускать анонимный доступ к некоторым почтовым ящикам. Анонимный пользователь регистрируется под именем anonymous, в качестве пароля используется адрес электронной почты пользователя, имя его домена, произвольный набор символов или пустая строка. Анонимный доступ возможен как при передаче пароля открытым текстом, так и с использованием SASL. Возможности анонимного клиента должны быть строго ограничены, как правило, он не получает прав на изменение какой-либо информации на сервере.

    STARTTLS

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

    LOGIN

    LOGIN регистрационное_имя_пользователя пароль

    Аутентификация при помощи регистрационного имени и пароля, передаваемых открытым текстом.

    AUTHENTICATE

    Передача зашифрованных аутентификационных данных с использованием SASL.

    Команды аутентифицированного состояния

    В аутентифицированном состоянии клиент производит различные манипуляции с почтовыми ящиками.

    SELECT

    Открывает доступ к указанному почтовому ящику. Сеанс переходит в состояние выбора, после этого клиент может работать с отдельными сообщениями в ящике.

    В ответ на эту команду сервер присылает ряд непомеченных ответов, содержащих информацию о почтовом ящике: количество сообщений, список допустимых флагов, количество новых сообщений, номер первого непрочитанного сообщения, идентификатор почтового ящика.

    EXAMINE

    Аналогично команде SELECT , но почтовый ящик открывается только для чтения.

    CREATE

    Создает новый почтовый ящик или каталог.

    Если объект создается не в корневом каталоге, то надо указать путь к нему.

    Если на конце указанного имени стоит символ, используемый в качестве иерархического разделителя, создается каталог.

    DELETE

    Удаляет указанный почтовый ящик. Эта же команда удаляет также и каталоги, если они не содержат почтовые ящики.

    RENAME

    RENAME имя_ящика новое_имя_ящика

    Переименование почтового ящика.

    SUBSCRIBE

    Почтовый ящик помечается как «активный». Эта пометка используется для вывода списка почтовых ящиков при помощи команды LSUB.

    UNSUBSCRIBE

    Снимает с почтового ящика пометку «активный». Эта пометка может быть снята с почтового ящика только при помощи команды UNSUBSCRIBE. Даже если ящик больше не существует, это не может само по себе стать причиной снятия пометки «активный».

    LIST путь_к_ящику имя_ящика

    Возвращает список каталогов и почтовых ящиков, соответствующих указанным аргументам.

    В имени ящика могут использоваться групповые символы: * , обозначающий любые символы и % , обозначающий любые символы кроме иерархических разделителей.

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

    В ответ сервер присылает одну или несколько непомеченных строк с ключевым словом LIST. Каждая из них содержит атрибуты, если таковые имеются, иерархический разделитель и имя почтового ящика или каталога, отвечающего заданным в аргументах условиям. Атрибуты заключаются в скобки, иерархический разделитель – в кавычки.

    RFC 3501 предусматривает четыре атрибута:

    • \Noinferiors – объект нижнего уровня иерархии – почтовый ящик, не каталог
    • \Noselect – объект – каталог, он не может быть выбран командой SELECT
    • \Marked – почтовый ящик отмечен как представляющий интерес, это означает, что со времени последнего обращения к ящику туда были добавлены новые сообщения
    • \Unmarked – со времени последнего обращения в почтовый ящик не поступило новых сообщений

    В описанном в RFC 3348 расширении CHILDREN предусмотрены еще два атрибута, позволяющие определить, содержит ли каталог почтовые ящики или подкаталоги:

    • \HasChildren – каталог содержит почтовые ящики или подкаталоги;
    • \HasNoChildren – объект не содержит почтовых ящиков или подкаталогов, доступных пользователю, аутентифицированному в данном сеансе.

    Оставив пустым второй аргумент команды LIST , можно выяснить используемый в первом аргументе префикс пространства имен. В этом случае ответ сервера вместо имени ящика будет содержать имя корневого каталога, то есть префикс пространства имен с иерархическим разделителем на конце.

    Если оба аргумента команды LIST пустые, то сервер возвращает только используемый по умолчанию иерархический разделитель.

    LSUB путь_к_ящику имя_ящика

    Команда LSUB аналогична команде LIST , но она возвращает только имена почтовых ящиков с пометкой «активный».

    STATUS

    STATUS имя_ящика (имена_элементов)

    Возвращает запрошенные элементы информации об указанном почтовом ящике. Имена элементов информации разделяются пробелами и все вместе заключаются в скобки. Предусмотрены следующие имена элементов информации:

    • MESSAGES – общее количество сообщений в ящике
    • RECENT – количество новых сообщений
    • UIDNEXT –уникальный идентификатор, который изменяется всякий раз, когда в почтовый ящик помещается новое сообщение
    • UIDVALIDITY – уникальный идентификатор почтового ящика
    • UNSEEN – количество сообщений, не помеченных как прочитанные

    Ответ представляет собой непомеченную строку с ключевым словом STATUS , за которым следует имя опрашиваемого почтового ящика, после которого в скобках перечисляются имена запрошенных элементов и их числовые значения.

    Добавляет сообщение в конец указанного почтового ящика. В качестве аргументов указываются имя ящика, флаги сообщения (не обязательно), метка времени (не обязательно) и само сообщение – заголовок и тело.

    Имеются следующие флаги сообщений:

    • \ Seen – прочитано
    • \ Answered – написан ответ
    • \ Flagged – срочное
    • \ Deleted – помечено для удаления
    • \ Draft – черновик
    • \Recent – новое сообщение, оно поступило в почтовый ящик после окончания прошлого сеанса

    Если в команде указаны флаги, то они устанавливаются для добавляемого сообщения. В любом случае для сообщения устанавливается флаг \Recent.

    Если в команде задана метка времени, то это время будет установлено в качестве времени создания сообщения, в противном случае за время создания принимается текущее время.

    Поскольку сообщение состоит не из одной строки, используются литералы.

    Команды выбранного состояния

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

    CHECK

    Команда производит проверку выбранного почтового ящика, характер которой зависит от реализации программного обеспечения сервера.

    CLOSE

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

    EXPUNGE

    Из выбранного почтового ящика удаляются все помеченные для удаления сообщения. Для каждого удаляемого сообщения посылается непомеченный ответ, содержащий номер сообщения и ключевое слово EXPUNGE .

    SEARCH кодировка_символов критерии_поиска

    Поиск в выбранном почтовом ящике сообщений, отвечающих указанным критериям поиска.

    Необязательный первый аргумент команды состоит из слова «CHARSET» и названия кодировки, используемой в критериях поиска. Кодировку нужно указывать, только если она отличается от стандартной US-ASCII.

    Второй аргумент содержит один или более критериев поиска.

    Критерий поиска состоит из ключевого слова и аргумента. Критерии также можно объединять, заключая в скобки. Это бывает удобно при использовании ключевых слов NOT и OR.

    Непомеченные ответы на команду SEARCH содержат номера сообщений, отвечающих указанным критериям.

    FETCH

    FETCH х:у имя_элемента_сообщения_или_макрос

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

    Во втором аргументе перечисляются запрашиваемые информационные элементы.

    COPY х:у имя_ящика

    Копирует сообщения с номерами от х до у из текущего почтового ящика в указанный почтовый ящик.

    UID команда аргументы Команда UID принимает в качестве аргументов команды COPY, FETCH или STORE с их аргументами, но наряду с номерами сообщений в ответах указываются уникальные идентификаторы сообщений.

    Также команду UID можно использовать совместно с командой SEARCH. В этом случае интерпретация аргументов команды SEARCH не изменяется, но в ответах на эту команду будут приведены уникальные идентификаторы сообщений.

    Что такое код imap_body

    (PHP 3, PHP 4, PHP 5)

    imap_body — Read the message body

    Description string imap_body ( resource imap_stream, int msg_number [, int options] )

    imap_body() returns the body of the message, numbered msg_number in the current mailbox.

    The optional options are a bit mask with one or more of the following:

    FT_UID — The msg_number is a UID

    FT_PEEK — Do not set the \Seen flag if not already set

    FT_INTERNAL — The return string is in internal format, will not canonicalize to CRLF.

    imap_body() will only return a verbatim copy of the message body. To extract single parts of a multipart MIME-encoded message you have to use imap_fetchstructure() to analyze its structure and imap_fetchbody() to extract a copy of a single body component.

    Пред. Начало След.
    imap_binary Уровень выше imap_bodystruct

    Если Вы не нашли что искали, то рекомендую воспользоваться поиском по сайту:

  • Понравилась статья? Поделиться с друзьями:
    Кодинг, CSS и SQL