После того как получен код 354, клиент может начать передачу данных. МТА-сервер, в свою очередь, помещает принятые данные в
очереди входящих сообщений. Сервер не высылает никаких ответов до тех пор, пока
не получит комбинацию CRLF-точка-CRLF от клиента,
означающую конец передачи данных. Как показано в строках 16 и 17, в ответ на
полученную комбинацию CRLF-точка-CRLF, сервер выдает
код 250, что означает успешное окончание операции:
16. SENDER: .
17. RECEIVER: 250 OK
Для того, чтобы закончить почтовую транзакцию, клиент, по правилам
SMTP, обязан послать команду QUIT. Сервер, в свою очередь, отвечает кодом 221,
который подтверждает клиенту, что соединение будет закрыто, после чего
соединение действительно закрывается:
18. SENDER: QUIT
19. RECEIVER: 221 mit.edu Service closing transmission channel
В любой момент во время транзакции клиент может использовать команды
NOОР, HELP, EXPN и VRFY. В ответ на каждую команду сервер высылает клиенту
определенную информацию. В зависимости от ответа клиент может предпринять
определенные действия.
2.1.2.
Коды ответов SMTP.
В
спецификации SMTP требуется, чтобы сервер отвечал на каждую команду SMТР-клиента. МТА-сервер отвечает
трехзначной комбинацией цифр, называемой кодом ответа. Вместе с кодом ответа,
как правило, передается одна или несколько строк текстовой информации.
Каждая цифра в коде ответа имеет определенный
смысл. Первая цифра означает, было ли выполнение команды успешно (2), неуспешно
(5) или еще не закончилось (3). Простой клиент может анализировать только первую
цифру в ответе сервера, и на основании ее продолжать свои действия. Вторая и
третья цифры кода ответа разъясняют значение первой. В табл. 2 приведены
возможные значения кодов ответа SMTP.
Таблица
2
Коды ответа SMTP и их значение
Код
|
Значение
|
211
|
Ответ о состоянии
системы или помощь
|
214
|
Сообщение-подсказка
(помощь)
|
220
|
<имя_домена>
служба готова к работе
|
221
|
<имя_домена>
служба закрывает канал связи
|
250
|
Запрошенное действие
почтовой транзакции успешно завершилось
|
251
|
Данный адресат не
является местным; сообщение будет передано по маршруту
|
354
|
Начинай передачу
сообщения. Сообщение заканчивается комбинацией CRLF-точка-CRLF
|
421
|
<имя_домена>
служба недоступна; соединение закрывается
|
450
|
Запрошенная команда
почтовой транзакции не выполнена, так как почтовый ящик недоступен
|
451
|
Запрошенная команда не
выполнена; произошла локальная ошибка при обработке сообщения
|
452
|
Запрошенная команда не
выполнена; системе не хватило ресурсов
|
500
|
Синтаксическая ошибка в
тексте команды; команда не опознана
|
501
|
Синтаксическая ошибка в
аргументах или параметрах команды
|
502
|
Данная команда не
реализована
|
503
|
Неверная
последовательность команд
|
504
|
У данной команды не
может быть аргументов
|
550
|
Запрошенная команда не
выполнена, так как почтовый ящик и недоступен
|
551
|
Данный адресат не
является местным; попробуйте передать сообщение по маршруту
|
552
|
Запрошенная команда
почтовой транзакции прервана; дисковое пространство, доступное системе,
переполнилось
|
553
|
Запрошенная команда не
выполнена; указано недопустимое имя почтового ящика
|
554
|
Транзакция не выполнена
|
Значения первой цифры в коде ответа
SMTP
Цифра 1 означает, что сервер МТА принял команду,
от клиента требуется дополнительное подтверждение. Клиент обязан послать
дополнительную информацию о том, продолжать или прервать выполнение запрошенной
команды. Из табл. 2 видно, что SMTP не имеет в составе таких команд, то есть
коды ответа, начинающиеся с единицы, отсутствуют. В настоящее время команд
SMTP, которые бы потребовали дополнительного подтверждения, нет. Разработчики
ориентировались на то, что такие команды появятся, и зарезервировали для них
коды, начинающиеся с цифры 1.
Коды ответа, начинающиеся с цифры 2, означают, что
сервер МТА успешно завершил выполнение команды и ожидает появления новой. Код
ответа, начинающийся на 3, означает, что команда начала выполняться, но серверу
необходима дополнительная информация для ее завершения. Пример такого кода -
354. В ответ на него клиент МТА должен приступить к передаче почтового
сообщения. Код, начинающийся с цифры 4, означает, что сервер не принял команду,
и она не выполнена. Во всех ответах серии 400 предполагается, что ошибка
временная и клиент может попытаться ее исправить. Коды ответа серии 500 также
сообщают, что команда не выполнена. Кроме того, клиент не должен пытаться
повторить ту же команду еще раз (по крайней мере в составе той же
последовательности).
Значения второй цифры кода ответа
SMTP
Вторая цифра кода ответа обозначает категорию
ошибки. Цифра 0 обозначает синтаксическую ошибку. Команда может быть слишком
длинной, иметь неправильный аргумент или отсутствовать в списке команд сервера.
У сообщений с кодами 211 и 214 из табл. 2 вторая
цифра кода равна единице и оба они информационного характера. У команд с кодами
220, 221 и 421 вторая цифра — двойка, и все они имеют дело с передачей данных
или с коммуникационным каналом. Коды ответов, у которых вторая цифра равна пяти
(250, 450 и 550) связаны непосредственно с почтовой системой. В настоящее время
в SMTP не определены значения кодов, вторая цифра которых равна трем или
четырем.
Третья цифра кода ответа SMTP
Каждая отдельная строка сообщения должна иметь
собственную третью цифру в коде ответа. Рассмотрим, например, сообщения с
кодами от 500 до 504. Каждое сообщение означает отдельную синтаксическую
ошибку. Поскольку строки, описывающие различные виды ошибок, разные, то и коды
ответа должны отличаться друг от друга. Каждое сообщение об ошибке имеет свой
собственный порядковый номер в данной серии. Спецификация SMTP рекомендует, но не
обязывает использовать строго заданные текстовые строки в ответах MTA-сервера.
Ответ MTA-сервера может состоять из нескольких
строк специального формата. Каждая строка (кроме последней) многострочного
ответа начинается с кода ответа, дефиса (-), текста и комбинации CRLF.
Последняя строка многострочного ответа начинается с кода ответа, за которым
следует пробел:
123-Первая строка сообщения из нескольких строк
123-Код ответа, 123, не изменяется
123-1 сообщение может начинаться с цифры
123 Последняя строка начинается не с дефиса, а с пробела
За кодом каждой строки, кроме последней, следует
знак дефиса (-). Это необходимо, чтобы клиент MTA смог отличить
строку-продолжение ответа от последней строки. За кодом ответа в последней
строке всегда следует пробел.
2.1.3. Ограничения по размерам.
В стандарте SMTP сказано, что реализации SMTP не должны ограничивать
максимальную длину обрабатываемых объектов (возможно, для будущих ра ширений стандарта). Однако, в
настоящий момент SMTP ограничивает допустимые размеры следующими величинами,
приведенными в табл. 3.
Таблица
3
Ограничения на размеры объектов SMTP
Объект SMTP
|
Ограничение
|
User
|
Максимальная длина
имени пользователя: 64 символа
|
Domain
|
Максимальная длина
имени домена: 64 символа
|
Path
|
Максимальная длина обратного
маршрута или маршрута доставки, включая знаки пунктуации и символы-oграничители: 256 знаков
|
Command
line
|
Максимальная длина
командной строки, включая ключевое слово и символы CRLF: 512 знаков
|
Reply
line
|
Максимальная длина
строки ответа, включая код ответа и символы CRLF: 512 знаков
|
Text
line
|
Максимальная длина
текстовой строки, включая символы CRLF: 1000 знаков
|
Recipients
|
Максимальное количество
получателей сообщения (за одну транзакцию): 100
|
Если клиент МТА превысил ограничения на размер передаваемой
информации, сервер МТА отвечает одним из следующих кодов:
500 Line too long.
(слишком длинная строка)
501 Path too long.
(слишком длинный путь)
552 Too many recipients.
(слишком много получателей)
552 Too much mail data.
(слишком много данных в сообщении)
2.1.4. Промежуточные агенты.
Термин
“маршрут доставки” (forward-path) служит для
того, чтобы отличать почтовый ящик (mailbox), имя
которого абсолютно, от пути (он может быть различным), по которому следует
почта. Предположим, что нужно доставить два почтовых сообщения на один и тот же
сетевой компьютер. Оба сообщения имеют один и тот же адрес, однако, не
обязательно будут следовать по одному и тому же маршруту. Точно так же, если на
пришедшие сообщения выдаются ответы, они не обязательно будут следовать по
указанному обратному маршруту (reverse-path).
Как правило, конкретный маршрут для почты выбирается системным администратором.
Чтобы направить почту по нужному пути, используются значения маршрута доставки
и обратного маршрута, в которых указываются промежуточные агенты (relay agents). Промежуточный
агент доставки - это МТА, так называемый почтовый хаб
(mail hub), настроенный на
передачу транзитной почты. Чтобы доставить сообщение, местный агент
пользователя (UA) передает его местному МТА, который, в свою очередь, передает
его промежуточному агенту МТА. В следующем примере Smith@usc.edu
является почтовым ящиком, a HOST1, HOST2 и HOST3 -
промежуточными агентами:
MAIL FROM:<@HOSTI, @HOST2, @HOST3:Smith@usc.edu>
Промежуточные агенты присутствуют практически во
всех сетях, входящих в Internet.
Рис. 2 Почтовая система Интернет с участием
промежуточных агентов.
Чтобы упростить процесс конфигурации почтовой
системы, в локальной сети устанавливается один компьютер, служащий
промежуточным агентом (relay host).
Вся почта пользователей попадает сначала на него. Затем этот компьютер
рассылает сообщения по Internet. Кроме всего прочего,
такой компьютер может служить защитой фирмы от взломщиков-хакеров из Internet. Ограничивая общение локальной сети с внешним
миром до уровня почты, организация сводит до минимума риск нежелательного
вторжения в свои собственные системы. Кроме того, администрировать и защищать в
этом случае приходится единственный компьютер. SMTP в состоянии послать
сообщение непосредственно с компьютера пользователя на компьютер адресата в том
случае, если между ними существует прямое почтовое соединение. Но обычно между
двумя компьютерами находятся промежуточные агенты. Чтобы обеспечить доставку, в
почтовом сообщении нужно указать имя компьютера-получателя и точное
наименование почтового ящика.
Аргументом команды MAIL является обратный маршрут,
включающий имя источника сообщения и имена всех промежуточных агентов. Аргумент
команды RCPT - маршрут доставки, содержащий имя получателя сообщения. Обратный
маршрут описывает путь, который прошло сообщение, тогда как маршрут доставки
идентифицирует место назначения. Обратный маршрут используется SMTP, когда
нужно передать сообщение о случившейся ошибке или о невозможности доставить
сообщение, когда оно уже прошло через промежуточный агент. По мере продвижения
сообщения по Internet записи о его маршрутах
изменяются. В обязанности системных администраторов входит правильно
настраивать местные МТА на передачу сообщений промежуточному агенту, и
наоборот, промежуточные агенты на доставку сообщений местным MTA. Если у
промежуточного МТА изменится имя, то в конфигурации местного МТА нужно изменить
имя компьютера в системе DNS. Другие параметры конфигурации не изменяются.
Рассмотрим почтовую транзакцию между промежуточными
агентами SMTP. До того как сообщение будет передано следующему указанному в
маршруте (в поле ТО:) компьютеру, имя данного компьютера удаляется из маршрута
доставки и добавляется в начало обратного маршрута. К тому моменту, когда
сообщение достигнет пункта назначения, маршрут доставки будет содержать только
имя почтового ящика.
2.2. Усовершенствования
электронной почты.
Усилия по усовершенствованию электронной почты
прилагаются в трех направлениях. Они затрагивают доставку (организация информации
в служебных полях упаковки сообщения), обработку агентами пользователя
(информация в заголовке сообщения) и тело сообщения. Наиболее интересные
возможности предоставляет модификация тела почтового сообщения. Тело сообщения
может переносить мультимедиа-объекты, то есть являться двоичным файлом с
графической, звуковой или видеоинформацией.В этом
разделе рассматриваются существующие методы кодирования таких данных в почтовых
сообщениях Internet.
2.2.1. Расширения SMTP.
Расширенный SMTP (ESMTP, Extended SMTP) работает почти так же, как и обычный SMTP,
однако, команда-приветствие у него другая: EHLO (Extended
hello) вместо HELO. Чтобы выяснить, поддерживает ли МТА-сервер спецификацию ESMTP, МТА-клиент
посылает команду EHLO. Если сервер поддерживает ESMTP, он отвечает кодом 250.
Если нет, следует сообщение о синтаксической ошибке. В ответ на сообщение об
ошибке, клиент может выдать обычную команду HELO и далее выполнять стандартные
операции SMTP. Если сервер умеет обслуживать ESMTP, в ответ на приветствие, как
правило, он выдает многострочный ответ. Каждая срока ответа содержит
дополнительную команду ESMTP, с которой сервер знает, как работать. Пример
реакции ESMTP-сервера в ответ на команду EHLO:
250-mail.server.com
250-EXPN
250-HELP
250 TURN
Вторая, третья и четвертая строки ответа содержат названия
дополнительных команд сервера. Этот сервер обеспечивает обработку перечисленных
в табл. 1 дополнительных команд. Первыми шестью расширениями SMTP являются
команды: ЕXPN, HELP, TURN, SEND, SOML и SAML. Существует также расширение SIZE,
позволяющее SMTP-клиенту и серверу сообщать друг другу размеры передаваемого
сообщения. Если в ответе на команду EHLO присутствует ключевое слово SIZE,
значит, данное расширение обрабатывается. Если клиент МТА попытается передать сообщение,
превышающее предел размеров передаваемого сообщения для сервера, почтовая
транзакция не состоится (закончится с ошибкой). Максимальная длина сообщения
ограничивается по нескольким причинам. Основная состоит в том, что размеры
жестких дисков сервера всегда ограничены, и слишком длинное сообщение может не
поместиться на них. С другой стороны, свободное пространство на дисках сервера
может со временем увеличиться, и это сообщение будет принято при следующей
попытке. Максимальный размер сообщения следует сразу за кодом ответа 250.
Например:
250 SIZE 100000000
Это пример ответа SIZE для размера в 100 Мб. Клиент MTA анализирует
ответ SIZE и в случае необходимости предпринимает соответствующие действия.
Дополнительно клиент может указывать длину сообщения в команде MAIL. В
следующей ESMTP-команде клиент объявляет, что длина сообщения равна 500 Кб:
MAIL FROM: SIZE=500000
MTA-сервер ESMTP анализирует аргумент SIZE и
решает, принимать ему сообщение такой длины или сообщить об ошибке. Все это
происходит еще до начала передачи. Остальные несколько расширений SMTP, в
общем, подчиняются тем же правилам, что и рассмотренная только что команда
SIZE. То есть команда-расширение выдается в ответе сервера по запросу клиента
EHLO. Расширения можно использовать в ваших программах в соответствии со
спецификацией. В некоторых случаях расширение является просто дополнительной
возможностью. В других случаях расширение - дополнительный аргумент к
существующей команде (как в случае рассмотренной команды SIZE).
Местным
расширением является любое поле, команда или название опции, начинающееся с
буквы X.
При разработке собственных расширений почтовой
системы необходимо, чтобы имена всех новых объектов начинались с буквы X.
Например, пользовательский вариант декодирования тела сообщения должен
называться не DECODE, как можно было бы предположить, a
XDECODE. SMTP-сервер организации при этом должен включить местное расширение
XDECODE в список, выдаваемый по команде EHLO (с кодом ответа 250):
250 XDECODE
2.2.2. MIME.
Система MIME - наиболее впечатляющее расширение
для существующих почтовых систем. Она не предполагает вмешательства в
деятельность агентов передачи почты. Два агента пользователя, понимающие MIME,
могут общаться друг с другом при помощи обыкновенных МТА. В MIME к сообщению
просто добавляются несколько полей заголовка:
- MIME-Version (версия MIME)
- Content-Type (тип содержимого)
- Content-Transfer-Encoding
(типкодировкисодержимого)
- Content-ID (идентификатор содержимого)
- Content-Description (описание содержимого)
Номера версий
MIME меняются по мере его развития. Поле MIME-Version
задает номер версии расширения MIME, которое данный агент пользователя умеет
обрабатывать. Номер версии в заголовке предохраняет агента от неправильной
интерпретации сообщения, в случае, если версии MIME сообщения агента не
совпадают. Вот образец полей заголовка MIME-Version и
Content-Type:
Mime-Version: 1.О
Content-Type: TEXT/PLAIN; charset=US-ASCII
В этом примере сообщение создано MIME версии 1.0. Тип содержимого –
TEXT, подтип - PLAIN, кодовая таблица (набор символов) US-ASCII. В табл. 4
приведены существующие в данный момент типы и подтипы MIME.
Таблица
4
Существующие типы и подтипы MIME
Тип
|
Подтип
|
Описание
|
Text
|
Plain
|
Неформатированный
текст.
|
|
Richtext
|
Текст с элементами
форматирования и выделениями, например с курсивом, подчеркиваниями, жирными
буквами и т.д.
|
|
Enriched
|
Усовершенствованный и
упрощенный вариант подтипа richtext.
|
Multipart
|
Mixed
|
Тело сообщения состоит
из нескольких частей; обрабатывать последовательно.
|
|
Parallel
|
Тело сообщения состоит
из нескольких частей; обрабатывать параллельно.
|
|
Digest
|
Дайджест электронной
почты.
|
|
Alternative
|
Тело сообщения состоит
из нескольких частей; все части семантически идентичны.
|
Message
|
RFC822
|
В теле содержится
почтовое сообщение стандарта RFC 822.
|
|
Partial
|
Фрагмент почтового
сообщения.
|
|
External-Body
|
Указатель на
действительное почтовое сообщение (не включенное в тело данного сообщения).
|
Application
|
Octet-Stream
|
Произвольные двоичные
данные.
|
|
Postscript
|
Программа на языке Postscript.
|
Image
|
JPEG
|
Формат ISO 10918.
|
|
GIF
|
Графический формат
фирмы Compuserve.
|
Audio
|
Basic
|
Звук в 8-битном
ISDN-формате mu-law.
|
Video
|
MPEG
|
Формат ISO11172
|
Поля заголовка Content-ID и Content-Description могут отсутствовать. Первое служит для
идентификации MIME-содержимого электронного письма, а второе может содержать
дополнительное описание. Например, если MIME-содержимым является графический
образ, в поле Content-Description можно поместить
описание этого образа. В табл. 5 перечислены возможные значения Content-Transfer-Encoding, доступные в настоящее время.
Таблица
5
Допустимые значения поля Content-Tfansfer-Encoding
Content-Transfer-Encoding
|
Описание
|
7bit
|
Формат NVT-ASCII –
стандартный формат почтовых сообщений.
|
Quoted-printable
|
Полезен в случае, если
текст содержит небольшое количество восьмибитных
символов.
|
Base64
|
Формат, в котором три
байта данных упакованы в четыре шестибитных
значения.
|
8bit
|
Содержит текст, в
котором не все символы принадлежат стандартному набору ASCII (то есть в
некоторых установлен восьмой бит).
|
Binary
|
Восьмибитные
данные без символов окончания строки.
|
По умолчанию формат почтовых сообщений
удовлетворяет кодовому набору NVT-ASCII. 8-битные агенты МТА сейчас практически
отсутствуют, но как только они получат широкое распространение, вероятно,
передача бинарной и текстовой информации в 8-битной кодировке возрастет. В
настоящий момент для передачи 8-битной информации по 7-битным каналам Internet лучше всего использовать кодировки quoted-printable или base64.
2.2.3. Способы кодирования MIME.
Для кодирования небольшого количества 8-битных
данных в 7-битный формат NVT ASCII лучше всего подходит схема quoted printable.
8-битный символ в этой схеме представляется в виде последовательности из трех
символов. Последовательность всегда начинается со знака “равно” (=). Сразу за
знаком “равно” следует двузначное шестнадцатиричное
число, представляющее код ASCII кодируемого символа. Рассмотрим закодированную quoted printable
последовательность JAMSA PRESS. Хоть она и не содержит 8-битных символов, зато
позволяет хорошо проиллюстрировать принцип кодирования. Закодированное
сочетание JAMSA PRESS выглядит так:
=4A=41=4D=53=41=20=50=52=45=53=53
Другими словами, буква J имеет шестнадцатиричный
код ASCII 0x4A, буква А – 0х41 и т.д. Схема quoted printable передает ASCII код для каждого символа
последовательности. То есть для знака А (ASCII 0x4A) передается код знака
“равно” (ASCII 0x3D), код цифры 4 (ASCII 0x34) и код знака А (0х41). Данную
схему довольно удобно использовать, но она утраивает общее количество
информации в сообщении. Таким образом, область применения quoted
printable – сообщение с небольшим количеством
символов, в которых установлен старший (восьмой) бит. Основная часть сообщения
должна состоять обычных семибитных символов.
В отличие от quoted printable, кодирование Base-64 увеличивает размер сообщения
всего лишь на одну треть. Каждая последовательность из трех байтов (24 бита)
превращается в четыре шестибитовых (тоже 24 бита). Шестибитные символы соответствуют формату NVT ASCII и
приведены в табл. 6.
Таблица
6
Таблица кодировки Base-64
6 бит
|
ASCII
|
6 бит
|
ASCII
|
6 бит
|
ASCII
|
6 бит
|
ASCII
|
0
|
A
|
16
|
Q
|
32
|
g
|
48
|
w
|
1
|
B
|
17
|
R
|
33
|
h
|
49
|
x
|
2
|
C
|
18
|
S
|
34
|
i
|
50
|
y
|
3
|
D
|
19
|
T
|
35
|
j
|
51
|
z
|
4
|
E
|
20
|
U
|
36
|
k
|
52
|
0
|
5
|
F
|
21
|
V
|
37
|
l
|
53
|
1
|
6
|
G
|
22
|
W
|
38
|
m
|
54
|
2
|
7
|
H
|
23
|
X
|
39
|
n
|
55
|
3
|
8
|
I
|
24
|
Y
|
40
|
o
|
56
|
4
|
9
|
J
|
25
|
Z
|
41
|
p
|
57
|
5
|
10
|
K
|
26
|
a
|
42
|
q
|
58
|
6
|
11
|
L
|
27
|
b
|
43
|
r
|
59
|
7
|
12
|
M
|
28
|
c
|
44
|
s
|
60
|
8
|
13
|
N
|
29
|
d
|
45
|
t
|
61
|
9
|
14
|
O
|
30
|
e
|
46
|
u
|
62
|
+
|
15
|
P
|
31
|
f
|
47
|
v
|
63
|
/
|
Если количество байтов (символов) в сообщении не
кратно трем, используются дополняющие символы “равно”. Например, слово KEN в
формате Base-64 выглядит как “S0VO” (дополнительных символов не требуется).
Слово COPE в формате Base-64 выглядит как “Q09QRQ==” (требуются два
дополнительных символа-нуля). Слово JAMSA в формате Base-64 выглядит как
“SkFNU0E=” (требуется один дополнительный символ-ноль).
2.2.4. Реализации метода Base-64.
Далее рассмотрен процесс кодирования слова KEN
методом Base-64. Описания участвующих в процессе переменных:
BYTE cTemp,
cTempHigh, cTempLow;
BYTE cFirst6Bits, cSecond6Bits;
BYTE cThird6Bits, cFourth6Bits;
BYTE cFirstLetter
= ‘K’;
BYTE cSecondLetter
= ‘E’;
BYTE cThirdLetter
= ‘N’;
Кодирование данных по методу Base-64
Операторы
языка C/C++, реализующие способ кодирования Base-64:
cFirst5Bits = cFirthLetter
>> 2; (1)
cTemp
= cFirstLetter << 4; (2A)
cTempHigh
= cTemp & 0x30; (2B)
cTempLow
= cSecondLetter >> 4; (2C)
cSecond6Bits = cTempHigh
| cTempL w; (2D)
cTemp
= cSecondLetter << 2; (3A)
cTempHigh
= cTemp & 0x3C; (3B)
cTempLow
= cThirdLetter >> 6; (3C)
cThird6Bits = cTempHigh
| c TempLow; (3D)
cFourth6Bits =
cThirdLetter & 0x3F; (4)
Первым делом биты переменной сFirstLetter
(символа K) сдвигаются вправо на две позиции. Получается новый байт, содержащий
первые шесть бит нашей последовательности. Далее полученное значение
записывается в переменную cFirst6Bits. Дальше, чтобы получить следующее
значение, нужно объединить два младших бита первого символа (K) с четырьмя
старшими второго (E), т.е. нужно переместить первый и второй биты буквы K на
позиции 5 и 6 – они будут старшими битами следующего шестибитного
символа. Операция 2А, двоичный сдвиг влево на четыре позиции демонстрирует, как
это делается. Результат сдвига запоминается во вспомогательной переменной cTemp.
Сдвиг оператором 2А очищает позиции с 1 по 4, а
биты 3 и 4 буквы K теперь расположены на позициях 7 и 8. Позиции 7 и 8 необходимо
очистить, поскольку нам нужны только первые шесть битов нового символа. Для
этого выполняется оператор 2В, “двоичное И”. Битовая маска 00110000 (0х30)
очищает все позиции, кроме пятой и шестой (в них содержатся интересующие нас
данные). Поскольку биты 5 и 6 теперь старшие для нового символа Base-64,
результат помещается (оператором 2В) во вспомогательную переменную cTempHigh.
В результате оператора 2В имеется два старших бита
нового шестибитного символа. Биты с 1 по 4 должны
быть взяты из второго символа. Чтобы получить четыре бита из второго символа,
его содержимое сдвигается вправо на четыре позиции (оператор 2С). Результат
оператора 2 С помещается во вспомогательную переменную cTempLow.
Теперь в переменной cTempLow хранятся четыре младших
бита нового символа, а в переменной cTempHigh — два
старших. Для того чтобы их скомбинировать, мы используем оператор (2D)
двоичного ИЛИ. Результат операции заносится в переменную cSecond6Bits.
В третий шестибитный
символ должны попасть четыре младших бита символа Е и два старших бита символа
N. То есть нужно переместить четыре младших бита символа Е с позиций 1 - 4 на
позиции 3 - 6. Для этого оператор 3А сдвигает биты влево на две позиции и
помещает результат в переменную сТеmр. Сдвиг влево
очищает позиции 1 и 2 для следующих данных. Кроме того, необходимо убедиться,
что позиции 7 и 8 тоже свободны. Другими словами, нам нужны только биты в
позициях 3 - 6. Чтобы очистить ненужные и оставить нужные позиции, выполняется
оператор “двоичное И” с маской 00111100 (0х3С). Результат оператора 3В
помещается в переменную cTempHigh.
Далее два старших бита символа N необходимо
сдвинуть на позиции 1 и 2. Для этого выполняется оператор ЗС сдвига вправо на 6
позиций. Результат заносится в переменную cTempLow.
Теперь у нас есть четыре младших бита символа Е в переменной cTempHigh и два старших бита символа N в переменной cTempLow. Оператор 3D комбинирует значения двух этих
переменных при помощи двоичного сложения (ИЛИ) и помещает новое шестибитное значение в переменную cThird6Bits. Теперь
получить четвертое шестибитное значение становится
просто, т.к. все биты уже стоят на своих позициях с 1 по 6 в символе N.
Осталось маскировать значения битов позиций 7 и 8. Оператор 4 выполняет
“двоичное И” с маской 00111111 (Ox3F) и заносит результат в переменную
cFourth6Bits.
Декодирование данных по методу
Base-64
Операторы
языка C/C++, реализующие способ декодирования Base-64:
cTempHigh
= cFirst6Bits <<2; (5A)
cTempLow
= cSecond6Bits >> 4; (5B)
cFirstLetter
= cTempHigh | cTempLow;
(5C)
cTempHigh
= cSecond6Bits << 4; (6A)
cTempLow
= cThird6Bits >> 2; (6B)
cSecondLetter
= cTempHigh | cTempLow;
(6C)
cTempHigh
= cThird6Bits << 6; (7A)
cThirdLetter
= cTempHigh | cFourth6Bits; (7B)
Значенияполученныхчетырехшестибитныхсимволовформата
Base-64 хранятсявпеременных
cFirst6Bits, cSecond6Bits, cThird6Bits и cFourth6Bits. Операторы
с 5А по 7В демонстрируют, как декодировать эти значения. Чтобы получить каждый
байт (кроме третьего) в последовательности, производятся операции левого
сдвига, правого сдвига и битового ИЛИ. (Для третьего символа правый сдвиг не
нужен - требуются только левый сдвиг битовое ИЛИ.) Ключевой момент - знать, на
сколько позиций сдвигать в каждом направлении. Шесть битов первого символа
Base-64 являются старшими шестью битами первого байта данных. Их необходимо
переместить с позиций 1 - 6 на позиции 3 - 8. Для этого выполняется операция
сдвига влево на две позиции (оператор 5А). Поскольку эти биты старшие,
результат заносится в переменную cTempHigh. Теперь
требуются биты с позиций 5 и 6 из второго символа Base-64. В них занесены два
младших бита первого байта данных. Сдвиг вправо на четыре позиции оператором 5В
решает проблему. Результат оператора 5В заносится в переменную cTempLow. Теперь есть шесть старших битов в переменной cTempHigh и два младших бита в переменной cTempLow. Oператор 5С, битовое
ИЛИ, комбинирует их значения, и в результате получается первый байт данных.
Чтобы получить второй байт данных, выполняются
практически те же операторы. Только вместо сдвига влево на два и сдвига вправо
на четыре делается сдвиг влево на четыре, а вправо на два, как
продемонстрировано операторами 6А и 6В. Оператор 6С, битовое ИЛИ, комбинирует
полученные результаты операторов 6А и 6В и получает значение второго байта
данных. Биты с 1 по 6 четвертого символа Base-64 соответствуют младшим битам
третьего символа данных. Биты 7 и 8 символа данных содержатся на позициях 1 и 2
третьего символа Base-64. Поэтому значение третьего символа сдвигается вправо
на шесть позиций оператором 7А. Наконец, в результате оператора 7В, битовое
ИЛИ, получается третий байт данных.
Реализация алгоритма
Метод кодирования Base-64 оперирует с 24-битными величинами. Алгоритмы
кодирования и декодирования также оперируют 24-битными величинами. Другими
словами, хотя в предыдущем разделе и не рассматривались прототипы функций для
кодирования-декодирования Base-64, предполагалось, что у них 24-битные
аргументы. Алгоритм кодирования состоит из десятка очень быстрых (поскольку все
они работают с двоичной информацией) операторов, преобразующих три байта данных
в четыре шестибитных символа Base-64 и восьми строк с
такими же быстрыми операторами, преобразующими эти символы в три 8-битных
символа исходных данных.
2.3. Протокол доставки почты (POP).
Post Office
Protocol (POP) - протокол доставки почты пользователю
из почтового ящика. Многие концепции, принципы и понятия протокола POP
аналогичны SMTP. Команды POP практически идентичны командам SMTP, отличаясь в
некоторых деталях.
В настоящее время существуют две версии протокола
POP – РОР2 и РОРЗ. Обе версии обладают примерно одинаковыми возможностями,
однако, несовместимы друг с другом. Дело в том, что у РОР2 и РОРЗ разные номера
портов протокола. Между ними отсутствует связь, аналогичная связи между SMTP и
ESMTP. Протокол РОРЗ не является расширением или модификацией РОР2 - это
совершенно другой протокол. РОР2 тесно связан с протоколом SMTP. Набор и
структура команд РОР2 параллельны набору и структуре команд SMTP. РОРЗ, однако,
разработан с учетом специфики доставки почты на персональные компьютеры и
соответствующих операций.
Раньше почтовые сообщения большинства сетей
доставлялись непосредственно от одного компьютера к другому. Если пользователь
часто менял рабочие компьютеры или один компьютер принадлежал нескольким
пользователям, существовали определенные проблемы. В настоящее время
большинство систем электронной почты доставляют сообщения не на отдельные
компьютеры, а в специальные потовые ящики, находящиеся на почтовом сервере. Для
того, чтобы прочитать свою почту, пользователю необходимо войти в сеть и
получить доступ к почтовому серверу. Данный процесс достаточно сложен для
начинающих пользователей, удаленный вход часто запрещается администраторами по
соображениям безопасности, и, вдобавок ко всему, чтобы прочесть или отослать почту,
нужно было пользоваться почтовым агентом самого сервера. Специальный протокол
доставки почты POP и стал альтернативой всем вышеописанным проблемам.
Протокол РОРЗ
Конструкция протокола РОРЗ обеспечивает
возможность пользователю войти в систему и изъять накопившуюся почту, вместо
того чтобы предварительно входить в сеть. Пользователь получает доступ к РОР-серверу из любой системы в Internet.
При этом он должен запустить специальный почтовый агент (UA), понимающий
протокол РОРЗ. Во главе модели POP находится отдельный персональный компьютер,
работающий исключительно в качестве клиента почтовой системы. В соответствии с
этой моделью персональный компьютер не занимается ни доставкой, ни авторизацией
сообщений для других. Также сообщения доставляются клиенту по протоколу POP, а
посылаются по-прежнему при помощи SMTP. То есть на компьютере пользователя
существуют два отдельных агента-интерфейса к почтовой системе - доставки (POP)
и отправки (SMTP). Разработчики протокола РОРЗ называет такую ситуацию
“раздельные агенты” (split UA).
В протоколе РОРЗ оговорены три стадии процесса
получения почты: авторизация, транзакция и обновление. После того как сервер и
клиент РОРЗ установили соединение, начинается стадия авторизации. На стадии
авторизации клиент идентифицирует себя для сервера. Если авторизация прошла
успешно, сервер открывает почтовый ящик клиента и начинается стадия транзакции.
В ней клиент либо запрашивает у сервера информацию (например, список почтовых
сообщений), либо просит его совершить определенное действие (например, выдать
почтовое сообщение). Наконец, на стадии обновления сеанс связи заканчивается. В
табл. 7 перечислены команды протокола РОРЗ, обязательные для работающей в Internet реализации минимальной конфигурации.
Таблица
7
Команды протокола POP версии 3 (для минимальной
конфигурации)
Команда
|
Описание
|
USER
|
Идентифицирует
пользователя с указанным именем
|
PASS
|
Указывает пароль для
пары клиент-сервер
|
QUIT
|
Закрывает
TCP-соединение
|
STAT
|
Сервер возвращает
количество сообщений в почтовом ящике плюс размер почтового ящика
|
LIST
|
Сервер возвращает
идентификаторы сообщений вместе с размерами сообщений (параметром команды
может быть идентификатор сообщения)
|
RETR
|
Извлекает сообщение из
почтового ящика (требуется указывать аргумент-идентификатор сообщения)
|
DELE
|
Отмечает сообщение для
удаления (требуется указывать аргумент-идентификатор сообщения)
|
NOOP
|
Сервер возвращает
положительный ответ, но не совершает никаких действий
|
LAST
|
Сервер возвращает
наибольший номер сообщения из тех, к которым ранее уже обращались
|
RSET
|
Отменяет удаление
сообщения, отмеченного ранее командой DELE
|
В протоколе POР3 определено несколько команд, но
на них дается только два ответа: +OK (позитивный, аналогичен
сообщению-подтверждению АСК) и -ERR (негативный, аналогичен сообщению “не
подтверждено” NAK). Оба ответа подтверждают, что обращение к серверу произошло
и что он вообще отвечает на команды. Как правило, за каждым ответом следует его
содержательное словесное описание. Сейчас будут рассмотрены несколько типичных
сеансов РОРЗ, что даст возможность уловить последовательность команд в обмене
между сервером и клиентом.
Авторизация пользователя
После того, как программа установила TCP-соединение с портом протокола
РОРЗ (официальный номер 110), необходимо послать команду USER с именем пользователя
в качестве параметра. Если ответ сервера будет +OK, нужно послать команду PASS
с паролем этого пользователя:
CLIENT: USER kcope
SERVER: +OK
CLIENT: PASS secret
SERVER: +OK kcope's maildrop has 2 messages (320 octets)
...
(B почтовом ящике kcope есть 2 сообщения (320 байтов) ...)
Транзакции РОРЗ
После того, как стадия авторизации окончена, обмен переходит на стадию
транзакции. В следующих примерах демонстрируется возможный обмен сообщениями на
этой стадии. Команда STAT возвращает количество сообщений и количество байтов в
сообщениях:
CLIENT: STAT
SERVER: +ОК 2320
Команда LIST (без параметра) возвращает список сообщений в почтовом
ящике и их размеры:
CLIENT: LIST
SERVER: +ОК 2 messages (320 octets)
SERVER: 1 120
SERVER: 2 200
SERVER: . ...
Команда LIST с параметром возвращает информацию о заданном сообщении:
CLIENT: LIST 2
SERVER: +ОК 2 200 ...
CLIENT: LIST 3
SERVER: -ERR no such message, only 2 messages in maildrop
Команда TOP возвращает заголовок, пустую строку и первые десять строк
тела сообщения:
CLIENT: TOP 10
SERVER: +OK
SERVER: a blank line, and the first 10 lines of the message body>
(сервер POP высылает заголовки сообщений, пустую строку и первые десять строк тела сообщения)
SERVER: . ...
CLIENT: TOP 100
SERVER: -ERR no such message
Команда NOOP не возвращает никакой полезной информации, за исключением
позитивного ответа сервера. Однако, позитивный ответ означает, что сервер
находится в соединении с клиентом и ждет запросов:
CLIENT: NOOP
SERVER: +OK
Следующие примеры показывают, как сервер POP3 выполняет действия.
Например, команда RETR извлекает сообщение с указанным номером и помещает его в
буфер местного UA:
CLIENT: RETR 1
SERVER: +OK 120 octets
SERVER: (РОРЗ-сервер высылает сообщение целиком)
SERVER: .
Команда DELE отмечает сообщение, которое нужно удалить:
CLIENT: DELE 1
SERVER: +OK message 1 deleted...
(сообщение 1 удалено)
CLIENT: DELE 2
SERVER: -ERR message 2 already deleted
(сообщение 2 уже удалено)
Команда RSET снимает метки удаления со всех отмеченных ранее
сообщений:
CLIENT: RSET
SERVER: +OK maildrop has 2 messages (320 octets)
(в почтовом ящике 2 сообщения (320 байтов))
Команда QUIT закрывает соединение с сервером:
CLIENT: QUIT
SERVER: +OK dewey POP3 server signing off
CLIENT: QUIT
SERVER: +OK dewey POP3 server signing off (maildrop empty)
...
CLIENT: QUIT
SERVER: +OK dewey POP3 server signing off (2 messages left) ...
Отмеченные для удаления сообщения не удаляются до
тех пор, пока не выдана команда QUIT и не началась стадия обновления. В любой
момент в течение сеанса клиент имеет возможность выдать команду RSET, и все
отмеченные для удаления сообщения будут восстановлены.
3. Организация службы
электронной почты в сети Интернет.
Основную роль в системе электронной почты играют
программы трех типов:
- транспортные
агенты (MTA - Mail Transport
Agent),
- агенты доставки
(MDA - Mail Delivery Agent),
- пользовательские
агенты (MUA - Mail User
Agent).
Взаимодействие этих программ и работа системы
электронной почты представлены на рисунке:
www.microsoft.com.
Простая и приятная в использовании, эта программа, по нашему опыту,
наиболее корректно работает с письмами на русском языке. Не поддерживает
IMAP.
http://tucows.rinet.ru/.
Поддерживает IMAP и имеет большое количество разнообразных настроек. Не
свободна от дефектов, особенно при работе с русскими сообщениями.
www.eudora.com, более полная версия
продается за деньги. Ранее пользовалась очень большой популярностью, но с
появлением бесплатных программ других производителей практически перестала
развиваться. Категорически не рекомендуется для переписки по-русски.
Когда вы
впервые запускаете почтовую программу, автоматически запускается мастер по
настройке, который запрашивает у вас минимально необходимую информацию: ваш
адрес и название серверов входящей и исходящей почты. Также может отдельно
запрашиваться имя пользователя - это та часть вашего адреса, которая находится
слева от знака @. При первой проверке почты и при всех последующих проверках,
если вы не пометили галочкой "Запомнить пароль", вас приглашают
ввести пароль - при этом надо внимательно следить, чтобы он был введен в
латинице.
Следует также
проверить остальные настройки. Если ваша программа поддерживает как POP3, так и
IMAP, нужно проследить, чтобы был выбран POP3, если провайдер специально не
предупредил вас об обратном. Если почтовая программа позволяет посылать письма
как в формате простого текста, так и в формате HTML, желательно выбрать простой
текст, как более универсальный. Если вы используете модемное соединение, то
лучше отменить настройку "Посылать почту немедленно". Проверьте
также, чтобы не была задействована настройка "Оставлять почту на
сервере" - иначе ваш почтовый ящик на сервере у провайдера будет все время
расти и со временем переполнится. Если же вы просматриваете почту с разных
компьютеров, например из дома и с работы, удобно, чтобы один из них оставлял
почту на сервере. На втором тогда будет накапливаться полный архив вашей
переписки. Большинство остальных настроек имеет декоративное значение и зависит
от ваших предпочтений. Например, ваша программа может автоматически
инициировать соединение с провайдером, когда вы хотите отослать почту (не
рекомендуется), автоматически разрывать соединение с провайдером, получив почту
и т.д.
Закончив
конфигурировать почтовую программу, вы можете проверить, как она работает. В
первую очередь следует найти две кнопки: одна позволяет проверить почту, другая
- создать новое сообщение. Нажмите на вторую из них - появится новое окно.
Здесь вы заполняете следующие поля:
Кому: (To) - понятно само собой;
Копия: (Cc:) - другие адресаты;
Bcc: - кому еще, но так, чтобы про это не знал
основной адресат;
Тема: (Subject:) - о чем ваше письмо,
заполнять не обязательно, но очень желательно;
наконец, большое поле под
перечисленными выше служит для самого текста письма. Текст вы можете
сопроводить приложением - для этого найдите соответствующую кнопку (часто она
обозначена скрепкой), которая позволит вам выбрать любой файл с вашего жесткого
диска. В качестве приложения можно посылать любые файлы: программы, звуковые
файлы, графические файлы и т.д. Если теперь, не закрывая почтовой программы, вы
соединитесь с провайдером и нажмете на кнопку "Послать", то ваше
письмо уйдет к адресату. Для начала вы можете послать письмо на свой собственный
адрес.
Теперь нажмите на кнопку, которая
служит для проверки почты, и вы получите назад свое сообщение. Оно попадет в
папку для входящих писем. Каждая почтовая программа после установки
автоматически создает как минимум три папки: для входящих писем, для исходящих
- здесь сохраняются копии того, что вы посылаете, и мусорная корзина - сюда
временно поступают удаляемые письма на тот случай, если вы стерли их по ошибке.
Откройте пришедшее сообщение, дважды щелкнув по нему мышью, и изучите имеющиеся
здесь элементы управления. Наиболее важные кнопки здесь - это
"Ответить" и "Переслать". Первая избавляет от необходимости
вводить адрес того, кому вы отвечаете, а вторая позволяет переслать письмо
кому-то еще.
Все остальное
в почтовой программе относится к категории удобств. Обычно вы можете создавать
дополнительные папки, чтобы сортировать по ним приходящую почту, заводить одну
или несколько адресных книг с часто используемыми адресами, автоматически
фильтровать входящую почту (например, автоматически направлять в мусорную
корзину письма с определенного адреса) и т.п. Эти дополнительные возможности
стоит изучать по мере необходимости и по мере роста объема вашей переписки. Они
подробно описаны в документации на вашу почтовую программу, в пункте меню "Help" (или "Справка").
5. Особенности национальной переписки.
Наверное, нет
такого пользователя, который бы не сталкивался с теми или иными проблемами при
переписке на русском языке. Почта подвержена этому даже больше, чем веб. Вы часто можете получить или полностью неудобочитаемое
письмо, или письмо с изуродованным полем "Тема:". Впервые получив
такое сообщение, пользователи склонны обвинять своего провайдера. Между тем он
здесь совершенно не при чем.
Общая причина
этих неприятностей - это недостаток стандартизации, причем сразу в двух
областях. Во-первых, так же как на вебе, сказывается
отсутствие единой общепринятой кодовой таблицы для русского алфавита. Мы уже
обсуждали это в предыдущей главе. В электронной почте чаще всего используется
кодировка КОИ-8, но может использоваться и Windows
CP1251, и, в редких случаях, другие кодировки. Само по себе это не страшно,
потому что современные почтовые программы умеют правильно показывать сообщения
в обеих кодировках, но только если отправляющая почтовая программа правильно
указала использованную кодировку в заголовке письма. Eudora,
например, этого не делает, что является грубым нарушением стандарта.
Во-вторых,
исходно электронная почта была рассчитана на передачу текстовых английских
сообщений по 7-битным каналам связи. Впоследствии был разработан новый стандарт
(MIME (см. выше)), который позволяет переписываться на других
языках и допускает приложения к письмам в виде произвольных файлов. Стандарт
получился сложным: для сохранения преемственности он предполагает передачу
8-битных сообщений по 7-битным каналам, и использует для этого разнообразные
схемы перекодирования информации. В результате почти все почтовые программы не
полностью соответствуют стандарту в каких-то мелких деталях. Например, Netscape Messenger (версия 4.5)
правильно кодирует поле "Тема:", заполненное по-русски, только если
оно не слишком длинное.
По-видимому, сейчас вы не сможете полностью избежать
проблем, связанных с перепиской по-русски. Но вы можете значительно их
уменьшить. Во-первых, используйте современные почтовые программы, которые
понимают обе распространенные русские кодировки. Хотя от привычной программы
трудно отказываться, от Eudor'ы, например, следует
отказаться. Посоветуйте то же самое своим корреспондентам.
Во-вторых, пишите письма, используя кодировку КОИ-8 -
она является наиболее общепринятой для почты. Не посылайте почту в формате
HTML, если точно не знаете, что почтовая программа вашего адресата поддерживает
этот формат. Любая почтовая программа поддерживает чисто текстовые сообщения.
Если ваш адресат жалуется, что не может прочесть ваше
письмо, вы можете еще раз послать его в виде приложения, например, в виде
документа Word. Приложения, как правило, проходят без
изменений. Или напишите то же самое в волапюке.
Volapuk - eto zapis'
russkogo teksta latinskimi bukvami.
Если вам пришло неудобочитаемое сообщение, попросите
его автора послать его снова, и укажите, какой формат письма для вас
предпочтителен. Обычно после нескольких проб и ошибок переписка налаживается и
в дальнейшем происходит без проблем.
6. Работа с почтой через браузер.
Вы можете
пользоваться почтой и не имея почтовой программы. Существует большое количество
серверов, которые предлагают вам завести бесплатный почтовый ящик и позволяют
работать с почтой, используя только браузер. Такие службы есть как в России (, ), так
и за ее пределами (, и
др.). Бесплатные почтовые службы живут за счет доходов от рекламы.
Такое
использование почты имеет определенные достоинства. Вы можете легко менять
провайдеров, не меняя свой адрес электронной почты. Вы можете просматривать
почту с любого компьютера, подключенного к Интернету, и не тратить время на
конфигурирование почтовой программы. Разумеется, у такого способа есть и свои
недостатки. Вы не можете при работе с почтой через браузер минимизировать время
подключения к Интернету в той мере, в какой это позволяют почтовые программы.
Кроме того, общедоступные почтовые сервера часто перегружены.
Лучше всего
комбинировать достоинства обоих способов. Многие пользователи заводят почтовые
ящики и у своего провайдера, и в общедоступной почтовой службе. Последний
используется во время поездок, и на это время на него перенаправляется вся
почта.
7. Списки рассылки, веб-форумы и группы новостей.
Одно из важных
достоинств электронной почты состоит в том, что она позволяет рассылать одно и
то же сообщение сразу большому числу адресатов. В простейшем случае вы перечисляете
дополнительные адреса в поле Сс: (Копия:) при
составлении письма. Если вам приходится то и дело посылать сообщения одной и
той же группе, например, из десяти человек, такой способ становится
нерациональным. Вместо этого вы можете создать в адресной книге своей почтовой
программы один групповой адрес, перечислив в нем все индивидуальные адреса. При
составлении очередного письма вы затем просто указываете этот групповой адрес в
поле "Кому:". Это простейшая форма списка рассылки;
его может создать любой пользователь.
Однако
обычно под списком рассылки подразумевается другая служба, требующая поддержки
со стороны провайдера. Эта служба позволяет пользователям самим вносить себя в
список рассылки (подписываться на него) и удалять себя из этого списка
(прекращать подписку). Сама терминология напоминает о газетах и журналах, и
действительно, списки рассылки выполняют те же функции, что и бумажные
периодические издания. Только здесь нет резкой границы между журналистами и
публикой, и нет строгой периодичности - списки рассылки в большей степени
напоминают коллективные разговоры. Они оказались незаменимым средством для
организации рабочих групп, осуществляющих какой-то проект, но могут
использоваться и просто для общения с себе подобными.
Серверное программное обеспечение для поддержки
списков рассылки называется менеджером
списков рассылки. Вы работаете со списком рассылки, используя два почтовых
адреса: административный и обычный. Посылая короткие стандартные команды по
административному адресу, вы можете подписаться на список рассылки, прекратить
подписку, получить список всех подписчиков и т.п. Обычный адрес служит
непосредственно для обмена сообщениями - письма на этот адрес получают все
подписчики данного списка рассылки. Например, послав письмо с единственной
строчкой "subscribe fadrnews"
по административному адресу majordomo@fadr.msu.ru, вы
подпишетесь на список рассылки под названием fadrnews.
С этого момента все сообщения на адрес fadrnews@fadr.msu.ru
будут поступать к вам, наряду с другими подписчиками. Полный список
административных команд вы можете получить, послав письмо с единственным словом
"help" по административному адресу.
Списки рассылки бывают модерируемыми и немодерируемыми.
В модерируемых списках рассылки каждое сообщение
предварительно направляется на одобрение главному редактору, который называется
модератором, в немодерируемых списках рассылка
происходит автоматически. Подписка происходит автоматически в открытых списках рассылки и направляется на одобрение модератору в
закрытых. Модератор нужен прежде всего для того, чтобы не допустить массовую
рассылку сообщений рекламного характера.
Найти наиболее интересный для вас список рассылки
как правило несложно - их адреса приводятся на веб-страницах,
посвященных соответствующей тематике, или находятся с помощью поисковых служб.
Подпишитесь на него, и вы будете каждый день получать по почте свежую
информацию, безо всяких дополнительных усилий с вашей стороны. Если вы захотите
организовать собственный список рассылки, обратитесь к своему провайдеру,
указав при этом, какой список вы хотите завести, - модерируемый
или нет, закрытый или открытый. Большинство провайдеров оказывает такую услугу.
Списки рассылки - это не единственный способ
обмена информацией в пределах группы людей, связанных общими интересами. Группы новостей выполняют такие же функции, но используют для этого
специализированное программное обеспечение и свой протокол под названием NNTP.
Существуют многие тысячи групп, посвященных различным вопросам, от компьютерных
протоколов то туризма. В отличие от списков рассылки, они существуют не по
отдельности, а объединены в общую иерархию. Вы можете участвовать в них,
используя Microsoft Internet News (входит в состав Windows 95 начиная с версии OSR2) или Netscape Messenger, который поддерживает
не только почту, но и новости. Этим программам необходимо указать название сервера новостей своего провайдера. Так же как и почтой, новостями
можно пользоваться при помощи браузера, используя сервер deja.com. Сообщество
пользователей, которое сложилось вокруг групп новостей (Usenet),
имеет давнюю историю и богатые традиции.
Веб-форумы выполняют те же функции, что и списки рассылки, но
используют для этого только браузер. Они выглядят как обычные веб-страницы, организованные таким образом, что каждый
пользователь может дописывать в них свое сообщение. В качестве примера можно
посмотреть веб-форум, посвященный каячному
спорту ().
В настоящее время веб-форумы представляют собой
наиболее удобное и простое средство для групповых дискуссий и объявлений, но
требуют более продолжительного подключения к Интернету по сравнению со списками
рассылки.
8. Спам и
почтовый этикет.
При всем
удобстве, электронная почта предоставляет богатые возможности для разного рода
злоупотреблений. Наиболее распространенным злоупотреблением является спам - массовая рассылка сообщений рекламного характера. Спаммеры используют как раз то достоинство электронной
почты, о котором мы только что говорили, - легкость рассылки по большому числу
адресов, но используют его в своих интересах. Вообще электронная почта - это
воплощенная мечта рекламных агентов, она позволяет массово распространять
рекламу за счет рекламополучателя, так сказать,
наложенным платежом.
До конца 80-х годов, пока Интернет охватывал в
основном университеты, спам не представлял особой
проблемы. По мере коммерциализации Интернета доля спама
все нарастала, и в последние годы он стал настоящим бедствием. По имеющимся
оценкам, спам сейчас порождает более 40% всего трафика электронной почты и
групп новостей. Возникла целая индустрия, обслуживающая интересы спаммеров, торгующая списками адресов для массовой рассылки
и специализированными программами. Удивительнее всего, что специалисты по
распространению спама в основном считают, что делают
полезное и нужное людям дело, и горячо выступают в защиту свободы слова.
В последние несколько лет законодатели многих стран
усиленно занимаются выработкой законов, направленных на борьбу со спамом. Однако законотворческий процесс, традиционно не
очень быстрый, откровенно буксует в новой для себя области. Отдельные штаты США
уже приняли законы о спаме, но государственных
законов нет ни в США, ни в России, ни в других странах. Кроме того, законы даже
государственного уровня не могут решить проблем такой международной сети, как
Интернет.
То, что не удается регулировать законами, до некоторой
степени удается регулировать договорами. Большинство Интернет-провайдеров,
заключая договор с пользователем, вставляют туда пункт о запрещении массовой
(веерной) рассылки рекламных материалов. Если вы нарушаете этот пункт,
провайдер блокирует вам доступ в Интернет, расторгает договор и не возвращает
оставшиеся на вашем счету деньги. Одновременно происходят необходимые изменения
в программах. Например, раньше вы могли использовать SMTP-сервер любого
провайдера в качестве сервера исходящей почты. Сейчас вы чаще всего можете
указывать сервер исходящей почты только своего провайдера, от других вы
получите сообщение "We do
not relay" ("Мы
не отсылаем чужую почту"). Это делается для того, чтобы можно было
однозначно определить, пользователь какого провайдера занимается рассылкой спама. Провайдеры, которые не ограничивают рассылку спама со своих серверов, попадают в черный список, и другие
провайдеры перестают принимать от них почту.
Что делать, если вы начинаете получать письма со
схемами быстрого обогащения или рекламой памперсов?
Лучше всего попытаться отследить источник сообщения и вежливо поставить в
известность соответствующего провайдера. Для этого нужно посмотреть полный
заголовок письма; в разных программах это делается по-разному. В Internet Mail, например, для
этого нужно щелкнуть правой кнопкой мыши по сообщению и выбрать пункт меню
"Свойства" и закладку "Подробно". Вы увидите несколько
строчек, которые начинаются со слов "Received: from..." ("Получено: от..."). Каждый из
серверов, через которые проходило данное сообщение, добавляет в его начало
такую строчку со своим названием. Самая первая (самая нижняя) из них дает вам
название сервера-отправителя. Например, если эта строчка выглядит так:
Received: from host1.mail.ru by
host2.mail.ru,
то
пошлите жалобу по адресу postmaster@host1.mail.ru или root@host1.mail.ru. Не
забудьте процитировать в полном объеме полученное вами письмо, вместе с полным
заголовком. Возможно, вы не получите ответа, но нужные действия будут скорее
всего предприняты.
Вообще для электронной почты сложились определенные
правила этикета, которые лучше соблюдать.
Не посылайте очень больших файлов в качестве
приложений. Помните, что ваш адресат, как правило, платит за то, чтобы получить
ваше письмо. Если у вас быстрое подключение к Интернету, вам не доставит
никаких затруднений приложить к письму графический файл объемом несколько
мегабайт, например, елочку на Новый Год. Вашему адресату эта елочка доставит
мало радости, если он будет получать ее по модему. Почта вообще не
предназначена для обмена большими файлами, для этого есть другие способы.
Будьте
взаимно вежливы. Электронная почта делает переписку настолько простой и
удобной, что это подводит некоторых пользователей. Они просто не успевают
остыть, а письмо уже оказывается отосланным. Письма, написанные в запале,
получили название флеймов.
Не цитируйте в ответе все письмо, на которое вы
отвечаете. Крайний случай - это когда цитируется длинное письмо, а ответ
состоит из фразы "Совершенно согласен".
И не посылайте свою рекламу в не предназначенные для
этого места. Порядочные люди так не делают.
Когда вы участвуете в электронной дискуссии, вы не
видите, как улыбается или пожимает плечами ваш собеседник, чтобы показать, что
он просто шутит. В электронном общении нет языка жестов. То, что вам кажется
шуткой, кто-то может принять за оскорбление. Чтобы предотвратить срыв из-за
таких недоразумений и бурные ссоры, у нас есть "улыбки" -
"смайлики" (Smile - улыбка). Поверните
голову влево и посмотрите на то, что идет за этой фразой. :-). Или просто :).
Это и есть основной смайлик. Он означает, что не следует принимать всерьез некоторый
предшествующий комментарий. Смайлик делается из двоеточия, дефиса и закрывающей
круглой скобки. Некоторые предпочитают слово "grin"
(усмешка). Иногда для краткости ставят просто букву.
Вот еще некоторые смайлики:
;-)
|
Подмигиваю;
|
:-(
|
Поморщился;
|
:-O
|
Поражен;
|
8-)
|
В
очках;
|
=|:-)=
|
Эйб Линкольн.
|
Два
последних немножко искусственны :-).
9. Шифрование почты и цифровая
подпись.
Когда вы
посылаете письмо по электронной почте, вы на самом деле посылаете не письмо, а
открытку. В принципе на всем пути от вашего компьютера до компьютера вашего
адресата ваше сообщение могут подстерегать любопытные глаза, как частные, так и
специально на это уполномоченные.
Государство
всегда проявляло большой интерес к частному общению своих граждан. Это касается
любых средств связи, от почты до Интернета, и относится к любым государствам,
от тоталитарных до демократических. Разница в том, что спецслужбы
демократических государств не ведут себя так откровенно, но и они стремятся
получить столько прав, сколько им позволяет общество.
Например, во
время Гражданской войны в США между Севером и Югом государственные органы
активно стремились взять под контроль телеграфное сообщение. Телеграфные услуги
тогда предоставляли многие компании, в том числе и мелкие, похожие на современных
Интернет-провайдеров. Некоторые телеграфисты тогда предпочли сесть в тюрьму, но
не закладывать интересы своих клиентов, и после ряда судебных процессов тайна
переписки была законодательно распространена на телеграф. Во Франции до 20-х
годов телефон был запрещен для использования частными лицами из опасения, что
преступники получат современные средства связи.
Интернет в
принципе позволяет государственным спецслужбам создать высоко
автоматизированную систему тотальной слежки, и они активно работают над этим
вопросом во всех странах. Упрекать их - это примерно то же самое, что призывать
хищников к вегетарианству. Тем не менее, как избирателя и налогоплательщика вас
может заинтересовать, на что и насколько эффективно расходуются ваши средства.
Одним из
широко обсуждаемых сегодня инициатив ФСБ является законопроект СОРМ-2 (Система
Оперативно-Розыскных Мероприятий), который предполагает создание выделенных
линий связи от ФСБ к каждому провайдеру и возможность тайного копирования любой
информации, без санкции суда или прокурора. SORM-2 противоречит, в частности,
23-й статье Конституции Российской Федерации, которая гарантирует тайну любой
переписки.
Если обычные
письма вы привыкли посылать в конвертах, то имеет смысл ознакомиться со
средствами шифрования электронной почты. Это не сделает из вас
шпиона, так же как запечатывание писем не свидетельствует ни о преступном
умысле, ни о мании преследования.
Вы, наверное, знаете, что нерасшифровываемых
шифров не бывает. Это было совершенно верно - но только до недавнего времени.
На беду спецслужб всех стран, криптография сейчас серьезно обогнала криптоаналитику. Это означает, что, используя доступные
средства, вы можете так зашифровать свое послание, что никакое ЦРУ его не
расшифрует.
Фактическим стандартом для шифрования почты стала
программа под названием PGP. Она бесплатна для
некоммерческого использования и сопровождается открытым исходным кодом. Ее
версия для Windows легко интегрируется в почтовые
программы. Автор программы - Филип Зиммерман - подвергался преследованию со стороны
американских властей, потому что американское законодательство запрещает вывоз
из страны сильных криптографических продуктов и приравнивает это к экспорту
вооружений. Любопытно, каким образом программа была вывезена из США: для этого
исходный код программы был отпечатан в виде книг. Вывоз книг не может быть
запрещен по американским законам.
PGP использует
асимметричное шифрование. Это значит, что вы создаете для себя два ключа для
шифрования - закрытый и открытый. Открытый ключ вы можете свободно
распространять - его будут использовать для шифрования почты, направленной на
ваш адрес. Для расшифровки вы будете использовать свой закрытый ключ, который
необходимо хранить в секрете. Тем самым отпадает необходимость предварительного
обмена ключом для шифрования, используя другие каналы, помимо Интернета.
Закрытый ключ не может быть вычислен из открытого.
Сейчас Группа
по Интернет-Технологиям (IETF) утверждает PGP в
качестве стандарта Интернета для шифрования почтовой переписки. Вы можете
совершенно законно использовать PGP в России, если не имеете доступа к
государственным тайнам.
Не менее
важно, что PGP позволяет вам подписывать свое письмо, используя ваш закрытый
ключ. Ваш адресат может проверить эту подпись, используя ваш открытый ключ,
причем она не только однозначно устанавливает вас как автора сообщения, но и
перестает быть правильной, если документ был каким-то образом изменен в
процессе передачи. Невозможно не только подделать цифровую
подпись, но и впоследствии изменить содержание подписанного документа.
Сегодня самые консервативные из государств
осознали, что без Интернета они будут отставать от своих конкурентов. Интернет
все больше превращается в среду для бизнеса, а это требует надежных средств
шифрования и цифровых подписей. Поэтому попытки любых государственных органов
взять Интернет под контроль или запретить средства шифрования выглядят довольно
нелепыми и свидетельствуют о расточительности и некомпетентности. Все равно не
будут работать законы, которые предписывают рекам течь вспять.
Заключение.
Основная привлекательность электронной почты - ее быстрота. Когда сеть
ARPANET впервые вышла на арену, ее разработчики ожидали, что преобладающим
будет трафик (то есть объем информации, передаваемой между узлами) типа
"процесс-процесс". Они ошиблись. К их великому изумлению, объем
электронной почты между людьми перекрыл объем связи между процессами. В то
время, как снег, дождь, жара могли остановить почтовых курьеров, возможности
сети ARPANET доставлять сообщения от западного побережья Соединенных Штатов к
восточному в течение нескольких секунд начали революционные процессы в
средствах сообщения.
Однако есть
другие преимущества, которые не так широко известны. Телефон также
предоставляет почти мгновенный доступ, но исследования показали, что около 75%
телефонных вызовов заканчиваются безуспешно ("Я очень сожалею, но мистер
Смит на совещании/уехал в командировку/вышел из комнаты."). Электронная
почта имеет ту же скорость доступа, что и телефон, но не требует одновременного
присутствия обоих абонентов на разных концах телефонной линии.
Удобство такого средства связи трудно
переоценить. Быстрота, дешевизна, необременительность, возможность передавать
информацию любого объема в любую точку мира. Неудивительно, что электронная
почта приобрела такую широкую популярность среди пользователей не только сети Интернет,
но и других достаточно популярных сетей – таких, как Fidonet, Bitnet
и AOL.
Как уже
говорилось ранее, невозможно в рамках одной курсовой работы в полной мере
осветить эту проблему, но я надеюсь, что мне удалось хоть в какой-то степени
дать ответы на основные вопросы – вопросы адресации, а также рассмотреть
принципы организации протоколов приёма и передачи и самой службы электронной
почты сети Интернет. На мой взгляд, немаловажными являются также и вопросы,
касающиеся как сетевого этикета в целом, так и почтового в частности, тем
более, что по мере того, как развитие сети Интернет стремится к бесконечности,
уровень грамотности и самосознания большей части его обитателей, к сожалению,
стремится к нулю. Страшно подумать, но безграмотность и неуважение в сети
становится своего рода шармом… Но это уже тема для другой курсовой работы.
??????
государственный ?????? университет
кафедра ??????
Курсовая работа по дисциплине «???????»:
«Электронная почта как сервис глобальной
сети. Протоколы передачи почты».
??????? – 2004.
Содержание.
Введение.
1.
Адресация в системе электронной почты.
1.1.
Структура адреса.
1.2.
Посылка
электронной почты в другие сети.
1.3.
Формат почтового
сообщения.
2.
Протоколы приёма и передачи почты.
2.1. Простой
протокол передачи почты (SMTP).
2.1.1.
Команды SMTP и их
последовательность.
2.1.2.
Коды ответов SMTP.
2.1.3.
Ограничения по размерам.
2.1.4.
Промежуточные агенты.
2.2. Усовершенствования электронной почты.
2.2.1. Расширения
SMTP.
2.2.2. MIME.
2.2.3.
Способы кодирования MIME.
2.2.4.
Реализация метода Base-64.
2.3. Протокол доставки почты (POP).
3.
Организация службы электронной почты в сети Интернет.
4.
Почтовые программы.
5.
Особенности национальной переписки.
6.
Работа с почтой через браузер.
7.
Списки рассылки, веб-форумы
и группы новостей.
8.
Спам и почтовый
этикет.
9.
Шифрование почты и цифровая подпись.
Заключение.
Список литературы.
Список литературы.
1.Эви Немет, Гарт Снайдер и др. UNIX:
руководство системного администратора.–К.:BHV, 1996
2.Персональные компьютеры в сетях TCP/IP – Киев,
издательская группа BHV, 1997
3.Э.А. Якубайтис, «Информатика-электроника-сети». М., «Финансы и статистика»,
1989
4.
On-line manual pages for Linux.
5.
ftp://ftp.relcom.ru/pub/internet/faq/geozone4.zip - географическиезонысетиИнтернет.
6.www.citmgu.ru – сервер информационных технологий.
7.www.athena.vvsu.ru – курс «Технологии Интернет».