Dydaktyka:
FeedbackTo jest stara wersja strony!
Możesz dowiedzieć się który terminal jest używany przez twoją powłokę wykonując:
echo $TTY
W dowolnym momencie możesz z innego terminala wykonać komendę która spowoduje
wyłączenie bądź włączenie wyświetlania wpisanych przez znaków:
stty -F /dev/pts/8 -echo
stty -F /dev/pts/8 echo
Używając tej metody możesz (częściowo) uniknąć pokazywania na ekranie wpisywanego z klawiatury hasła.
W trakcie przesyłania wiadomości e-mail między serwerami SMTP najpierw
przesyłana jest są adresy z "koperty" (envelope), potem jej zawartość (contents).
Zawartość (contents) każdej wiadomość e-mail składa się z nagłówków (headers)
i treści (body).
MAIL FROM:<grey@cat.baz> \ envelope RCPT TO:<john@example.com> / ("koperta") DATA From: Greebo <grey@cat.baz> \ \ To: John Q. Public <john@example.com> | headers | contents Date: Mon, 13 Jan 2025 03:00:00 +0100 | (nagłówki) | ("zawartość") Subject: Khhhhhhhhhhhhh / | | KhIIIIsss! ] body (treść) / .
Zauważ że używany do dostarczenia wiadomości adres odbiorcy znajduje się na
"kopercie". Adres docelowy który jest w nagłówkach w jej zawartości nie jest
brany pod uwagę przy ustalaniu dokąd wiadomość ma zostać wysłana.
"Koperta" jest tworzona tylko na czas wymiany zawartości między serwerami i
użytkownicy poczty nie widzą adresów które tam były podane (choć serwer
odbierający może przepisać adres z rcpt to do nagłówka Received).
Linie muszą się kończyć przez \r\n, lista nagłówków przez \r\n\r\n.
To: <first_recepient@example.com>, <second_recepient@example.com>, <third_recepient@example.com>
Mój przykładowy tekst (gdzie w UTF-8 ó to binarnie \0xC3\0xB3 a
ł to \xC5\x82) można w nagłówku Subject zakodować jako: =?UTF-8?Q?M=C3=B3j?= =?UTF-8?Q?Przyk=C5=82adowy?= tekst lub =?UTF-8?Q?M=C3=B3j_przyk=C5=82adowy_tekst?= (używając Quoted-Printable) lub =?UTF-8?B?TcOzaiBwcnp5a8WCYWRvd3kgdGVrc3Q=?= (używając base64).
Na liście nagłówków musi się znaleźć nagłówek Date i From.
Format daty określa standard, w Linuksie można uzyskać prawidłowo sformatowaną
datę komendą date --rfc-email.
Na liście nagłówków powinny znaleźć się też Message-ID, oraz jeśli
wiadomość jest odpowiedzią, In-Reply-To oraz References.
Na liście nagłówków powinien się znaleźć się też nagłówek Subject.
Autor wiadomości musi też ustawić przynajmniej jeden z nagłówków To, Cc
lub Bcc (a jeżeli autor ustawi tylko Bcc, to już MUA może usunąć ten
nagłówek z treści i wiadomość transportowana po SMTP nie ma żadnych adresów
docelowych w nagłówkach).
____ ┌─────┐ ┌─────┐ ┌─────┐ ┌─────┐ ┌─────┐ .------.
(mail) → │ MUA │-→-→-→│ MSA │-→-→-→│ MTA │-→-→-→│ MTA │-→-→-→│ MDA │ → (skrzynka)
‾‾‾‾ └─────┘ SMTP └─────┘ SMTP └─────┘ SMTP └─────┘ SMTP └─────┘ `------‘
\____/ \_________________/ \____/
wysłanie przekazanie dostarcznie
(submission) (relay) (delivery)
Podział MTA na MSA, MTA i MDA jest umowny.
Współcześnie każdy kolejny agent odbierając wiadomość sprawdza czy ta nie jest spamem.
.------. ┌─────┐ ┌─────────┐ (skrzynka) ← │ MAA │ ← ← ← │ MRA/MUA │ `------‘ └─────┘ POP3/IMAP └─────────┘Po tym jak wiadomość wyląduje w skrzynce, trzeba ją stamtąd pobrać. Do tego używa się protokołów protokołu POP3 lub IMAP.
Kolejne kroki komunikacji SMTP, przy założeniu że serwer zaakceptuje wszystkie polecenia: (więcej w RFC dla SMTP i dla AUTH):
220EHLO nazwa_domenowa (lub starszym HELO nazwa_domenowa) i poczekać na akceptację serweraAUTH metoda; w wynikach komendy EHLO podane są wspierane przez serwer metody (lista ustandaryzowanych metod jest tutaj)AUTH metoda klient musi poczekać na odpowiedź; serwer zwróci albo kod 5xx określający że się nie zgadza, albo odpowiedź spodziewaną w wybranej metodzieAUTH PLAIN:\0użytkownik\0hasło i zakodowane w base64. echo -n "User:"; read -rs U; echo -n "\nPass:"; read -rs P; echo; printf "\0%s\0%s" "$U" "$P" | base64MAIL FROM:nadawca i poczekać na akceptację serweraRCPT TO:odbiorca i poczekać na akceptację serweraDATA i czeka na odpowiedź od serwera (354)\r\n.\r\n serwer wysyła akceptację do klientaMAIL FROM) lub zakończyć połączenie wysyłając komendę QUIT
W SMTP odpowiedź na niektóre komendy może składać się z wielu linii.
W takim przypadku wszystkie poza ostatnią linią mają składnię kod-treść,
a ostatnia linia kod treść.
Klient może wysłać następną komendę dopiero po otrzymaniu odpowiedzi na
poprzednią.
Przykład komunikacji:
220 example.org ESMTP EHLO sub.domain.baz 250-example.org hello sub.domain.baz 250-AUTH LOGIN PLAIN 250 8BITMIME AUTH PLAIN 334 AHVzZXIAcGFzc3dvcmQ= 235 Authentication succeeded MAIL FROM:user@example.org 250 OK RCPT TO:friend@example.org 250 Accepted RCPT TO:mellon@doriath.mi 250 Accepted DATA 354 Enter message, ending with "." on a line by itself From: <user@example.org> Date: Mon, 13 Jan 2025 00:00:00 +0000 Zorg . 250 OK id=1tXOtg-007aSz-0m QUIT 221 example.org closing connection
SMTP definiuje też komendy:
SMTP używa portów:
smtp) do nieszyfrowanych połączeńsmtp) do szyfrowanych połączeń (TLS), ustanawianych po użyciu komendy STARTTLS na nieszyfrowanym połączeniusmtps, znane też jako urd) do szyfrowanych połączeń (TLS)submission) do nieszyfrowanych połączeńsubmission) do szyfrowanych połączeń (TLS), ustanawianych po użyciu komendy STARTTLS na nieszyfrowanym połączeniu(Zobacz też: https://www.cloudflare.com/learning/email-security/smtp-port-25-587/)
Połączenie bez szyfrowania można wykonać np. programem socat (lub nc,
jeśli serwer przeżyje kończenie linii przez samo \n):
socat tcp:adres_serwera:smtp,crlf readline
lub tandetniejsze socat tcp:adres_serwera:smtp,crlf stdio jeśli masz
debianopochodnego
Linuksa
Połączenie od razu z szyfrowania można wykonać np. programem socat lub openssl:
socat ssl:adres_serwera:smtps,crlf readline
openssl s_client -quiet -verify_quiet -crlf adres_serwera:smtps
Na portach 25 i 587 połączenie początkowo jest nieszyfrowane.
Klient musi wysłać najpierw polecenie EHLO nazwa_domenowa, następnie
wysłać polecenie STARTTLS, po akceptacji którego następuje nawiązanie
połączenia TLS.
Program openssl s_client umie w taki właśnie sposób nawiązać połączenie
z serwerem SMTP po podaniu komendy:
openssl s_client -quiet -verify_quiet -crlf -starttls smtp adres_serwera:submission
Można też wskazać własną nazwę wpisywaną do komendy EHLO przez:
openssl s_client -quiet -verify_quiet -crlf -starttls smtp -name nazwa_domenowa_do_ehlo adres_serwera:submission
Po nawiązaniu połączenia TLS klient powinien ponownie wysłać komendę EHLO
(a serwer powinien zapomnieć o poprzedniej).
Zadanie 1 Znajdź dowolną stronę oferującą usługę typu 10 minute mail. Zostawiając do kolejnych ćwiczeń otwartą kartę ze swoim 10-cio minutowym adresem mail w przeglądarce, sprawdź jaki serwer obsługuje pocztę dla domeny z której jest ten adres.
Zadanie 2
Przygotuj do skopiowania i wklejania (np. w edytorze tekstu) treść komunikacji
od klienta do serwera bez uwierzytelniania, w tym treść samej wiadomości.
W zawartości wiadomości mają się znaleźć nagłówki From, To, Subject
i Date.
Zarówno RCPT TO jak i To mają wskazywać na twój 10-cio minutowy adres.
Zadanie 3 Połącz się bez szyfrowania z serwerem odbierającym maile z domeny twojego 10-cio minutowego maila i wyślij wcześniej przygotowany mail. Następnie sprawdź czy dotarł i czy został prawidłowo zrozumiany przez pocztę.
Zadanie 4
Przygotuj polecenia które będziesz musiał wpisać żeby wysłać mail ze swojej
poczty studenckiej (albo innej własnej poczty) z uwierzytelnieniem metodą PLAIN
do adresów dwóch osób siedzących obok (lub do innych swoich adresów, wedle
uznania).
W zawartości wiadomości mają się znaleźć prawidłowe nagłówki From,
To lub Cc, Subject i Date oraz niepusta treść maila.
Zadanie 5
Połącz się używając portu 587 (submission) z użyciem STARTTLS do serwera
obsługującego twoją pocztę i wyślij wcześniej przygotowany mail. Następnie
sprawdź czy dotarł i jak wygląda.
Przykładowa komunikacja:
USER nazwa i komendę PASS hasło AUTH metoda (podobnie jak dla SMTP), np. AUTH PLAIN, po której wysyła dane uwierzytelniająceLIST (lub opcjonalnie wspierane UIDL) i dostaje listę numerów wiadomości (lub listę numerów wraz z unikalnym identyfikatorem wiadomości)RETR numer pobierającą wiadomość o podanym numerze (tyle razy ile potrzebuje)DELE numer zaznaczając wiadomość o podanym numerze jako do usunięcia (tyle razy ile potrzebuje)QUIT która usuwa wcześniej oznaczone wiadomościNumery na liście wiadomości to kolejne liczby naturalne, po usunięciu wiadomości i ponownym połączeniu wiadomości są numerowane na nowo.
Poza powyższymi, z istotnych funkcji protokół POP3 dopuszcza jeszcze komendę
pobierającą nagłówki i pierwsze N linii treści wiadomości (TOP) oraz
wyświetlającą które z opcjonalnych funkcji są wspierane przez serwer (CAPA).
Więcej w RFC dla POP3 i rozszerzeń do POP3.
POP3 używa portu 110 dla nieszyfrowanej komunikacji TCP i portu 995 dla szyfrowanej komunikacji SSL/TLS.
POP3 nie wspiera:
POP3 powstał po to, żeby użytkownik pobrał z serwera maile na swój komputer, usunął je z serwera zwalniając miejsce na kolejne maile. Tworząc ten protokół nie przewidziano korzystania z poczty na wielu komputerach ani istnienia klientów pocztowych innych niż lokalny program (protokół powstawał rok przed HTTP).
Wiele serwerów poczty wciąż oferuje POP3, stąd warto znać różnice między tym protokołem a protokołem IMAP.
W tej chwili powszechnie używana jest wersja IMAPv4rev1 oraz IMAPv4rev2 (w dużym stopniu kompatybilna z poprzednią).
W protokole IMAP przed każdą komendą klient musi podać identyfikator (tag)
będący dowolnym wymyślonym przez klienta ciągiem alfanumerycznym.
Przykładowa komunikacja w której klient wybrał tagi foo i baz:
foo search subject "SK2" baz search subject "sieci" * SEARCH 2 5 7 10 foo OK SEARCH completed * SEARCH 5 7 10 12 baz OK SEARCH completedKlient nie powinien powtarzać tagów. Większość programów generuje tagi doklejając kolejne numery za literę
A, tzn. A001, A002, …
W odpowiedzi na komendę serwer może przesłać linię zaczynającą się od:
+ serwer czeka na wpisanie czegoś przez klienta (np. w komendzie AUTHENTICATE na dane uwierzytelniające),* serwer przesyła linię z treścią odpowiedzi na komendę,OK/NO/BAD).Przykładowa komunikacja może składać się z:
CAPABILITY, dostaje w odpowiedzi możliwości serweraLOGIN nazwa hasło AUTHENTICATE metoda (podobnie jak dla SMTP), np. AUTHENTICATE PLAIN, po której wysyła dane uwierzytelniająceLIST "" *SELECT nazwa lub trybie tylko do odczytu komendą EXAMINE nazwaFETCH …, fetch 5 FULL pobierze wszystkie metadane wiadomości nr 5, fetch 6 BODY[] pobierze zawartość wiadomości nr 6, a fetch 100:200 BODY[HEADER.FIELDS (FROM TO DATE SUBJECT)] pobierze nagłówki From, To, Date i Subject dla wiadomości od 100 do 200 Fetch jest rozbudowana tak by w sprawny sposób można było przeglądać wiadomości bez ściągania z wszystkich wiadomości serweraSTORE …, STORE 42 +FLAGS (\Deleted) dodaje (patrz: +) jedyną w podanym zbiorze (patrz: (…)) flagę do wiadomości nr 42 określającą że wiadomość jest usunięta (\Deleted) STORE 56 +FLAGS (\Seen \Answered) doda dwie flagi, STORE 10:50 -FLAGS (\Flagged) usunie oznaczenie wiadomości jako ważnej dla wiadomości od 10 do 50 \Deleted komendą EXPUNGESEARCH …, SEARCH UNSEEN pokaże identyfikatory nieprzeczytanych wiadomości, SEARCH SUBJECT "foo" pokaże identyfikatory wiadomości które w tytule mają ciąg znaków foo SEARCH ma spore możliwości, patrz RFC; ta komenda ma pozwalać przeszukać skrzynkę bez ściągania z serwera wszystkich wiadomościUNSELECT'LOGOUT
IMAP używa dwóch numerów wiadomości: kolejnych numerów w skrzynce, zmieniających
się po usunięciu wiadomości, i unikalnych identyfikatorów, nadawanych jako
kolejne liczby naturalne.
Jeżeli komendy STORE, FETCH, SEARCH, … zostaną
poprzedzone komendą UID, to operują na unikalnych identyfikatorach.
Po wybraniu katalogu klient zawsze dostaje informację o tym jaki UID zostanie
nadany kolejnej wiadomości, co pozwala np. zorientować się jakie wiadomości
pojawiły się od ostatniego sprawdzania poczty.
Przy okazji każdej odpowiedzi serwer może przesłać dodatkowo np. linię
* num EXISTS wskazując że w skrzynce pojawiła się wiadomość
num.
W IMAP kiedykolwiek po zalogowaniu klient może też wysłać komendę IDLE
(RFC). W odpowiedzi na
nią serwer wysyła linię zaczynającą się od + i czeka na wysłanie przez
klienta linii składającej się ze słowa DONE, ale jednocześnie serwer będzie
na bieżąco raportować zdarzenia na skrzynce (takie jak pojawienie się nowych
maili) wysyłając linie zaczynające się od *.
Klient musi co nie więcej niż pół godziny wysyłać DONE i ponawiać komendę
IDLE jako keepalive pozwalający serwerowi poradzić sobie z zerwanymi
połączeniami.
Przykład komunikacji:
A CAPABILITY * CAPABILITY IMAP4rev1 IDLE UNSELECT A OK CAPABILITY completed B LOGIN user@example.org qwerty B OK [CAPABILITY IMAP4 IMAP4rev1 IDLE UNSELECT] User logged in C LIST "" * * LIST (\HasNoChildren) "/" "INBOX" * LIST (\HasNoChildren \Drafts) "/" "Drafts" * LIST (\HasNoChildren \Junk) "/" "Junk" * LIST (\HasNoChildren \Sent) "/" "Sent" * LIST (\HasNoChildren \Trash) "/" "Trash" C OK LIST completed D SELECT "INBOX" * FLAGS (\Answered \Deleted \Draft \Flagged \Seen) * 50 EXISTS * 0 RECENT * OK [UNSEEN 48] * OK [UIDNEXT 85] D OK [READ-WRITE] Completed E SEARCH UNSEEN * SEARCH 48 50 E OK SEARCH completed F UID SEARCH UNSEEN * SEARCH 82 84 F OK completed G SEARCH SINCE 1-JAN-2025 * SEARCH 46 47 48 49 50 G OK SEARCH completed H FETCH 49:50 BODY.PEEK[HEADER.FIELDS (SUBJECT)] * 49 FETCH (BODY[HEADER.FIELDS (SUBJECT)] {30} Subject: Meeting on Monday ) * 50 FETCH (BODY[HEADER.FIELDS (SUBJECT)] {33} Subject: Re: Meeting on Monday ) H OK FETCH completed I FETCH 50 BODY[] * 50 FETCH (BODY[] {715} Return-Path:Received: from mx.doriath.mi … Subject: Re: Meeting on Monday Ok, pasuje. ) I OK FETCH completed J IDLE + idling * 51 EXISTS DONE J OK IDLE completed K LOGOUT * BYE mail.example.org server closing connection K OK LOGOUT completed
IMAP używa do portów TCP:
imap) do nieszyfrowanej komunikacji,imap) do szyfrowanych połączeń (TLS), ustanawianych po użyciu komendy STARTTLS na nieszyfrowanym połączeniu,imaps) do szyfrowanych połączeń (TLS).
Odpowiednia komenda dla nawiązania połączenia z użyciem STARTTLS dla narzędzia openssl to:
openssl s_client -quiet -verify_quiet -crlf -starttls imap adres_serwera_imap:imap
Zadanie 6
Połącz się do swojej poczty studenckiej używając IMAP i znajdź nieprzeczytane
wiadomości w katalogu Inbox.
Zadanie 7
Znajdź, używając UIDów, wiadomości z katalogu Inbox które mają w temacie
"SK2" (albo inny wybrany ciąg znaków). Wyświetl nagłówki jednej z tych wiadomości
(np. komendą UID FETCH num BODY[HEADER]).
Zadanie 8
Wykonaj komendę IDLE i w trakcie jej trwania wyślij sobie maila.
Następne zakończ komendę IDLE, wyświetl otrzymaną wiadomość i oznacz ją jako
przeczytaną lub usuniętą.
Wstępne przetworzenie maili trafiających do skrzynki na serwerze, np. wrzucanie
do wybranych folderów na podstawie ustawionych filtrów, umożliwiają skrypty
sieve (patrz: RFC
strona "domowa") które można konfigurować używając
dedykowanego do tego protokołu.
Oczywiście sieve musi być wspierany przez serwer poczty i włączony przez
administratora tego serwera.
Każdy serwer SMTP dodaje nagłówek Received na początek każdej przetwarzanej wiadomości. Pozwala to określić przez jakie serwery przeszedł mail (szczegóły w RFC).
Nagłówek Received zawiera między innymi:
for informację o adresie wpisanym w RCPT TO z "koperty" SMTP.Zadanie 9 Prześledź nagłówki maila wysłanego do lub z poczty jakiegoś dużego serwera pocztowego. Przez ile serwerów przeszedł ten mail? Ile z nich jest częścią wewnętrznej infrastruktury nadawcy/odbiorcy?
Zadanie 10
Prześledź nagłówki dowolnego maila ze spamem. Jak mają się adresy podane za
słowem kluczowym for w nagłówku Received do adresów w To i Cc?
Nagłówki z adresami mają składnię Nagłówek: nazwa <adres>[, …], np.
To: John Q. Public <john@example.com>, <smith@example.com>
Poza oczywistymi From, To, Cc i Bcc używa się też nagłówków Reply-To do wskazania (jednego) adresu odpowiedzi i Return-Path do wskazania adresu na który maja być wysyłane komunikaty o niepowodzeniu dostarczenia wiadomości.
Wiele serwerów pozwala dodawać na koniec adresu, po określonym znaku, dodatkowy
tekst.
Np. jeżeli serwer pozwala na dodanie takiego tekstu po +, to mail wysłany
na adres john+shop@example.com trafi do tej samej skrzynki do której
trafiłby mail wysłany na adres john@example.com. Często pozwala to na
łatwiejsze filtrowanie wiadomości i kontrolę spamu. (To czy i jaki znak jest
używany zależy od konfiguracji serwera; przykłady dla wybranych serwerów są
na wikipedii).
Zadanie 11 Sprawdź nagłówki z adresami dowolnego maila z listy mailingowej.
Każdy mail powinien mieć ustawiony unikalny identyfikator w nagłówku Message-ID. Jeżeli MUA nie ustawił tego nagłówka, zrobi to MSA.
Odpowiadając na mail MUA wpisuje w nagłówek In-Reply-To identyfikator maila na który użytkownik odpowiada, oraz kopiuje (bądź tworzy) nagłówek References i dodaje identyfikator tego maila na koniec listy identyfikatorów wiadomości tego wątku.
Zadanie 12 Znajdź mail będący odpowiedzią na odpowiedź odpowiedzi. Zobacz jak wyglądają nagłówki In-Reply-To i References i porównaj je z Message-ID odpowiedzi na odpowiedź.
Określenie typu MIME powstało dla poczty – MIME to skrót od Multipurpose Internet Mail Extensions.
To czym jest treść wiadomości, określa nagłówek Content-Type.
Jeżeli nie podano nagłówka Content-Type, domyślnie przyjmowany jest czysty
tekst (text/plain).
Jeżeli wiadomość składa się z jednej części, to w nagłówkach wiadomości można
podać po prostu typ, np:
Content-Type: text/html; charset=utf-8.
Jeżeli wiadomość składa się z więcej niż jednej części, używa się specjalnych
typów
Content-Type: multipart/…; boundary=separator.
Te typy wskazują że treść to więcej niż jedna część i ustawiają separator
oddzielający te części na --separator.
Powszechnie wykorzystuje się kilka takich typów, np. mixed i alternate.
Każda część wiadomości ma powinna mieć powtórzony nagłówek Content-Type określający jakiego typu jest ta część, może mieć dodatkowe nagłówki porządkujące treść i te nagłówki muszą być oddzielone pustą linią od treści.
Typ multipart/alternate służy podaniu kilku wersji tego samego maila i
jest powszechnie używany do wysyłania maila jednocześnie w wersji HTML i
czystego tekstu.
Przykład takiej treści:
… inne nagłówki … Content-Type: multipart/alternate; boundary=oddzielacz --oddzielacz Content-Type: text/plain Przyjdzie o **jedenastej** wieczorem. --oddzielacz Content-Type: text/html <html><body><p>Przyjdzie o <b>jedenastej</b> wieczorem.</p></body></html> --oddzielacz
Zadanie 13 Znajdź w swojej skrzynce mail który ma dwie wersje. Czy faktycznie wersje są równoważne? Którą wyświetla domyślnie twój klient pocztowy?
Typ multipart/mixed służy do wysłania kilku niezależnych części i jest
używany do wysyłania z załącznikami.
Przykład:
… inne nagłówki … Content-Type: multipart/mixed; boundary=fikusny_separator --fikusny_separator Content-Type: text/plain Zobacz ten obrazek! --fikusny_separator Content-Type: image/png Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="mail.png" iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAAAAAA6mKC9AAAATElEQVQY04WOOQ7AQAwCZ1b+/5dJ ETvHpgjyISFAGN5YCNgjrP7GURBzioYgzEHcQ9mIFMRLHykg2AtU+0bVxCNq8am+oe6OJ8yf5QDW ShMmZmKfpQAAAABJRU5ErkJggg== --fikusny_separator
Zadanie 14 Znajdź w swojej skrzynce mail z załącznikami. Jaki Content-Transfer-Encoding został użyty do przesłania załączników?
Typu MIME moża w sobie dowolnie zagnieżdżać, więc można również:
… inne nagłówki … Content-Type: multipart/mixed; boundary=a --a Content-Type: multipart/alternative; boundary=b --b Content-Type: text/plain Zobacz ten obrazek! [IMG] --b Content-Type: multipart/related; boundary=c --c Content-Type: text/html <html><body><p>Zobacz ten obrazek!</p> <p><img src="cid:my-mail-img""></p></body></html> --c Content-Type: image/png Content-Transfer-Encoding: base64 Content-ID: <my-mail-img> iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAAAAAA6mKC9AAAATElEQVQY04WOOQ7AQAwCZ1b+/5dJ ETvHpgjyISFAGN5YCNgjrP7GURBzioYgzEHcQ9mIFMRLHykg2AtU+0bVxCNq8am+oe6OJ8yf5QDW ShMmZmKfpQAAAABJRU5ErkJggg== --c --b --a Content-Type: text/plain Content-Disposition: attachment; filename="licencja.txt" kopyrajt 2025 --a
O ile nagłówki wiadomości używają siedmiobitowego US-ASCII ze wsparciem dla encoded-words i trzymają się ograniczenia długości linii, o tyle w treści można zmienić kodowanie na sensowniejsze.
Kodowanie dla danej części wiadomości można ustawić w nagłówku
Content-Transfer-Encoding. Domyślna wartość to 7bit, nie pozwalająca w
ogóle na użycie znaków spoza US-ASCII.
Inne dozwolone kodowana to "normalne" 8bit i binary (pierwsze ogranicza
długość linii do 998 znaków, drugie nie nakłada ograniczenia na długość linii)
oraz quoted-printable i base64.
Content-Transfer-Encoding: quoted-printable (RFC)
bez zmian przesyła drukowalne znaki ASCII poza znakiem równości,
natomiast całą resztę (w tym np. spacje czy znaki nowej linii) koduje jako
=XX, gdzie XX to szesnastkowa wartość kodowanego znaku.
Powstały tekst zawija się przed 77 znakiem , wstawiając na koniec linii znak =.
Np. Einstein napisał: e=mc² z nową linią na końcu stanie się tekstem
Einstein=20napisa=C5=82:=20e=3Dmc=C2=B2=0D=0A.
Content-Transfer-Encoding: quoted-printable używa zwykłego base64 do zakodowania treści.
Np. Einstein napisał: e=mc² z nową linią na końcu stanie się tekstem
RWluc3RlaW4gbmFwaXNhxYI6IGU9bWPCsg0K.
Kodowanie base64 jest powszechnie używane do przesyłania nietekstowych
załączników i jest do tego celu niewydajne – base64 koduje 3 bit treści na
4 bitach danych, więc objętość wiadomości rośnie o ⅓.
Zadanie 15
Wyszukaj w swojej skrzynce przynajmniej dwa maile z polskimi znakami w treści
które używają różnych Content-Transfer-Encoding.