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

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

 

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

Google       Google       5. 7. 2006       18 335×

Častým problémem začínajících .NET vývojářů je odesílání e-mailů, proto se vás v příštích několika dílech pokusím seznámit se správným odesíláním e-mailových zpráv v prostředí .NET 2.0.

Reklama
Reklama

Jeden z nejčastěji pokládaných dotazů začínajících .NET vývojářů se týká odesílání e-mailů, proto se vás v následujících několika dílech pokusím s metodami odesílání e-mailů v prostředí .NET seznámit. Zpočátku se dozvíte něco o odesílání běžných zpráv, o metodách odesílání a jejich konfiguraci.

Vytvoření a odeslání zprávy

Zprávu vytvoříte vytvořením nové instance třídy System.Net.Mail.MailMessage – základní údaje o zprávě můžete nastavit přímo v jejím konstruktoru. V jednom z konstruktorů jsou požadovány 2 parametry typu System.Net.Mail.MailAddress – tato třída umožňuje zadat kromě e-mailové adresy i zobrazované jméno s jistotou, že se ve zprávě správně zakóduje.


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 = "Předmět zprávy";
    // tělo zprávy
    message.Body = "Tělo zprávy";
    // určení typu zprávy
    message.IsBodyHtml = true;

    // 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);
}

K odesílání zprávy slouží třída System.Net.Mail.SmtpClient. Třída mimo jiné umožňuje přihlášení k SMTP serveru, které probíhá prostřednictví třídy System.Net.NetworkCredential. Vlastnost DeliveryMethod, která je typu System.Net.Mail.SmtpDeliveryMethod, slouží k nastavení odesilací metody. Pokud vám to SMTP server dovolí, můžete přes vlastnost EnableSsl povolit zabezpečené odesílání zpráv.

Metody odesílání a jejich konfigurace

PickupDirectoryFromIis
Výchozí metoda, která použije mail pickup service lokálního IIS. K odeslání zprávy nemusí dojít, když .NET Framework není schopen načíst konfiguraci z IIS nebo když na serveru nejsou zapnuté SMTP services. Nepotřebuje žádné zvláštní nastavení.
SpecifiedPickupDirectory
Hodí se k vyřešení problému s načítáním konfigurace u předchozí metody, nebo když vlastně žádné e-maily posílat nechcete. Musíte specifikovat, jaký adresář se má použít, většinou C:\Inetpub\mailroot\Pickup.

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <system.net>
    <mailSettings>
      <smtp from="odesilatel@mail.cz" deliveryMethod="SpecifiedPickupDirectory">
        <specifiedPickupDirectory pickupDirectoryLocation="C:\Inetpub\mailroot\Pickup"/>
      </smtp>
    </mailSettings>
  </system.net>
</configuration>
Network
Mnou preferovaná metoda, která k odeslání použije jakýkoliv SMTP server, který vám odeslání dovolí. Většinou je potřeba se přihlásit. Musíte specifikovat alespoň adresu SMTP serveru. Tato metoda funguje prakticky pokaždé.

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <system.net>
    <mailSettings>
      <smtp from="odesilatel@mail.cz" deliveryMethod="Network">
        <network host="smtp.mail.cz" port="25" userName="Username" password="Password"/>
      </smtp>
    </mailSettings>
  </system.net>
</configuration>

Pod popisem metody je uveden příklad konfigurace, která probíhá v konfiguračním souboru aplikace – app.config v případě klientské aplikace a web.config v případě webové aplikace.

Závěrem

To je v 1. dílu vše, pokud vám tu něco podstatného chybí, neváhejte se zeptat v komentářích. Příště se dozvíte, jak správně odesílat přílohy a jak zobrazovat obrázkové přílohy v těle zprávy, aby je následně zobrazil každý klient pracující s HTML zprávami.

×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.

2 názory  —  2 nové  
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

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.

Reklama
Reklama
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í.

Obrázek ke článku Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Trend Micro, celosvětový lídr v oblasti bezpečnostních řešení a VMware, přední světový dodavatel cloudové infrastruktury a řešení pro podnikovou mobilitu, oznámily výsledky výzkumu mezi českými a slovenskými manažery zodpovědnými za ochranu osobních údajů, který zjišťoval, jak jsou připraveni na nové nařízení o ochraně osobních údajů (GDPR). Většina firem v České republice a na Slovensku nad 100 zaměstnanců je již s novým nařízením GDPR obeznámena. Výzkum provedený ve spolupráci s agenturou Ipsos ukázal, že téměř 8 firem z 10 o nařízení ví, přičemž jeho znalost je o něco vyšší na Slovensku (89 %) než v České republice (69 %).

Obrázek ke článku Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Jeden z nejznámějších ransomwarů, Locky, se vrací. Po většinu roku 2016 patřil mezi nejrozšířenější vyděračské softwary. Ke svému šíření využíval emailové kampaně s infikovanými přílohami. Ransomware Locky byl rozesílán prostřednictvím botnetu (internetový robot zasílající spamy) Necurs. Jeho aktivita na konci roku 2016 téměř upadla a spolu s ní i šíření ransomwaru Locky. Před několika týdny se Necurs opět probudil a začal posílat spamy nabízející výhodný nákup akcií. Dne 21. dubna zaznamenal bezpečnostní tým Cisco Talos první velkou kampaň ransomwaru Locky prostřednictvím botnetu Necurs za posledních několik měsíců.

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ý