Odesílání e-mailů – 2. díl
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Odesílání e-mailů – 2. dílOdesílání e-mailů – 2. díl

 

Odesílání e-mailů – 2. díl

Google       Google       9. 7. 2006       19 697×

V druhém, pravděpodobně posledním dílu se dozvíte, jak odesílat e-maily s přílohami a jak zobrazovat přiložené obrázky v těle e-mailu.

Reklama
Reklama

Dnes přímo navážu na předchozí díl a ukážu vám, jak snadné je odesílat e-maily s přílohami, jak zobrazovat přiložené obrázky v těle e-mailu a jak nastavit správný MIME typ přílohy pro zajištění správného zobrazení ve všech e-mailových kilentech.

Odesílání příloh

Klasickou přílohu reprezentuje třída System.Net.Mail.Attachment , přes kterou můžete připojit fyzický soubor nebo objekt typu Stream.


// vytvoření nové přílohy
System.Net.Mail.Attachment atach = new System.Net.Mail.Attachment("c:/soubor.jpg");
// nastavení MIME typu
atach.ContentType.MediaType = System.Net.Mime.MediaTypeNames.Image.Jpeg;
// přiložení přílohy do zprávy
message.Attachments.Add(atach);

Velmi důležité je správné určení MIME typu přílohy – zabráníte tak možným komplikacím při zobrazování na straně klienta.

Nezapomínejte správně určit MIME typ přílohy, můžete tak zabránit případným chybám v zobrazení na straně klienta.

Zobrazení obrázku v těle e-mailu

Možná vás někdy zajímalo, jak vlastně fungují obrázkové propagační e-maily, spamy, když žádný obrázek není umístěn na externím serveru ani jako běžná příloha. Vše spočívá v tom, že zvláštnímu typu přílohy přiřadíte určité ContentId a následně zobrazíte obrázek v HTML zprávě.


public void SendMail()
{
    // vytvoření nové zprávy
    System.Net.Mail.MailMessage message = new System.Net.Mail.MailMessage(new System.Net.Mail.MailAddress("odesilatel@mail.cz", "Odesílatel"), new System.Net.Mail.MailAddress("prijemce@mail.cz", "Příjemce"));
    // přiřazení dalšího příjemce - tímto bude mít zpráva 2 příjemce
    message.To.Add(new System.Net.Mail.MailAddress("prijemce2@mail.cz", "Příjemce2"));

    // předmět zprávy
    message.Subject = "Vložený obrázek";
    // určení typu zprávy
    message.IsBodyHtml = true;

    // přilinkování obrázku
    System.Net.Mail.LinkedResource lres = new System.Net.Mail.LinkedResource(@"C:\soubor.jpg");
    // přiřazení ContentId
    lres.ContentId = "img";
    // nastavení MIME typu
    lres.ContentType.MediaType = System.Net.Mime.MediaTypeNames.Image.Jpeg;

    // vytvoření alternativního zobrazení zprávy
    System.Net.Mail.AlternateView aview = System.Net.Mail.AlternateView.CreateAlternateViewFromString(@"Tělo zprávy.<br><img src=""cid:img"">", null, "text/html");
    // přiložení přilinkovaného obrázku
    aview.LinkedResources.Add(lres);

    // přiložení alternativního zobrazení ke zprávě
    message.AlternateViews.Add(aview);

    // vytvoření SMTP klienta
    System.Net.Mail.SmtpClient smtp = new System.Net.Mail.SmtpClient("smtp.mail.cz", 25);
    // pokud je to potřeba, můžete provést přihlášení k SMTP serveru
    smtp.Credentials = new System.Net.NetworkCredential("Username", "Password");
    // nastavení metody odesílání
    smtp.DeliveryMethod = System.Net.Mail.SmtpDeliveryMethod.Network;
    // můžete povolit nebo zakázat zabezpečené odeslání - některé SMTP servery nedovolují zabezpečené připojení
    smtp.EnableSsl = false;
    // odeslání vytvořené zprávy
    smtp.Send(message);
}

Znovu jsem uvedl celý kód, abyste se mohli podívat na změny. Obrázek není připojený jako běžná příloha, ale jako System.Net.Mail.LinkedResource, který se u klienta nezobrazí v seznamu příloh. I v tomto případě je dobré nastavit správný MIME typ. Není klasicky uvedené tělo zprávy message.Body, protože je vytvořený objekt System.Net.Mail.AlternateView, který po připojení ke zprávě celý obsah message.Body přepíše. Ve zvoleném konstruktoru AlternateView jsou tři parametry: text, kódování a MIME typ. Obrázek ve zprávě zobrazjete bežným tagem.

<img src="cid:img">

Jako src zvolte prefix cid: a následně ContentId, které jste přiřadili vašemu obrázku, v tomto případě je to img.

Závěrem

To je všechno, co jsem vám chtěl sdělit. Vaše dotazy pište do komentářů – mohou mě inspirovat k napsání dalšího dílu tohoto krátkého seriálu.

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
(fotka) Dušan JanošíkDušan vyvíjí software a webové aplikace na platformě .NET. Je milovníkem neuznávaných teorií, a zajímá se o parapsychologii a teraristiku.
Web     Twitter     Facebook     LinkedIn    

Nové články

Reklama
Reklama
Obrázek ke článku Blockchain & Bitcoin konference

Blockchain & Bitcoin konference

V pátek 19. 5. 2017 se v pražském konferenčním centru Andel’s konala Blockchain & Bitcoin konference. Řada odborníků a podnikatelů v oboru blockchainu a kryptoměn představila možnosti budoucího směřování tohoto oboru. Speakeři většinou rusky mluvící provenience prezentovali řešení svých firem založená na technologii blockchainu.

Obrázek ke článku Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Bezpečnostní tým Cisco Talos odhalil celkem 4 kampaně dosud neobjeveného malwaru, který dostal jméno KONNI. Ten se dokázal úspěšně maskovat od roku 2014. Zpočátku se malware zaměřoval pouze na krádeže citlivých dat. Za 3 roky se ale několikrát vyvinul, přičemž jeho současná verze umožňuje útočníkovi z infikovaného počítače nejenom krást data, ale i mapovat stisky na klávesnici, pořizovat screenshoty obrazovky či v zařízení spustit libovolný kód. Pro odvedení pozornosti oběti zasílali útočníci v příloze také obrázek, zprávu a výhružkách severokorejského režimu či kontakty na členy mezinárodních organizací.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý