程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> .net類庫中發送電子郵件的方法總結

.net類庫中發送電子郵件的方法總結

編輯:.NET實例教程


發送電子郵件是許多需要用戶注冊的網站的通用功能,通過正則表達式我們可以過濾掉不符合電子郵件格式的輸入,但是仍沒有辦法確保用戶填寫的電子郵件地址一定是他本人真實有效的電子郵件地址,通常驗證電子郵件真實有效的辦法是:當用戶填寫的注冊資料經過網站初步格式驗證之後,用戶並不能利用此帳號登錄,系統會向用戶注冊時填寫的電子郵件地址發送一封電子郵件,郵件中給出一個鏈接,只有當用戶點擊了這個鏈接之後才能登錄到網站,如果用戶填寫的電子郵件地址不是真實有效的或者不是他本人的,就不會收到這封電子郵件,這樣仍然不能登錄,這一步一般稱之為電子郵件激活。
在.net類庫中有兩種發送電子郵件的方式,一種是在.net2.0以下版本中的做法,一種是.Net2.0以上版本的做法。下面分別介紹這兩種辦法。

一、.net1.0及.Net1.1中的做法(利用CDOSYS消息組件發送電子郵件):

代碼如下:

using System; 
using System.Web.Mail;

/// <summary> 
/// 說明:在.Net2.0以下版本中發送電子郵件的方法示例 
/// 用到的類主要位於System.Web.Mail命名空間下 
/// 作者:周公 
/// 日期:2008-08-08 
/// 首發地址:http://blog.csdn.Net/zhoufoxcn 
/// </summary> 
public class SendMail 

    public SendMail() 
    { 
         
    } 
    /// <summary> 
    /// 發送郵件 
    /// </summary> 
    /// <param name="to">收件人郵件地址</param> 
    /// <param name="from">發件人郵件地址</param> 
    /// <param name="subject">郵件主題</param> 
    /// <param name="body">郵件內容</param> 
    /// <param name="username">登錄smtp主機時用到的用戶名,注意是郵件地址'@'以前的部分</param> 
    /// <param name="passWord">登錄smtp主機時用到的用戶密碼</param> 
    /// <param name="smtpHost">發送郵件用到的smtp主機</param> 
    public void Send(string to, string from, string subject, string body, string username, string passWord, string smtpHost) 
    { 
        MailMessage mail = new MailMessage(); 
        mail.To = to;//設置收件人地址 
        mail.From = from;//設置發件人地址 
        mail.Subject = subject;//設置郵件主題 
        mail.BodyFormat = MailFormat.Html;//設置郵件以Html格式發送 
        mail.Body = body;//設置郵件內容 
        //設置發送郵件時需要身份驗證 
        mail.FIElds.Add("http://schemas.microsoft.com/cdo/configuration/smtpauthenticate", "1"); 
        //設置登錄郵件主機時的用戶名,注意如果發件人地址是[email protected],則用戶名是abc而不是[email protected] 
        mail.FIElds.Add("http://schemas.microsoft.com/cdo/configuration/sendusername", userName); 
        //設置登錄SMTP主機的用戶密碼 
        mail.FIElds.Add("http://schemas.microsoft.com/cdo/configuration/sendpassword", passWord); 
        //設置發送郵件的SMTP主機 
        SmtpMail.SmtpServer = smtpHost;   //發送郵件,如果發送不成功會拋出異常 
        SmtpMail.Send(mail); 
    } 
}
上面的方法底層用到了CDOSYS組件,用到的類主要是System.Web.Mail.SmtpServer和System.Web.Mail.MailMessage,這種方法已經被微軟不贊成使用了,取而代之的是.Net2.0中的新增的類和方法。

 

二、.Net2.0中的做法

代碼:


using System; 
using System.Net.Mail; 
using System.Net;

/// <summary> 
/// 說明:在.Net2.0以上版本中發送電子郵件的方法示例 
/// 用到的類主要位於System.Net.Mail和System.Net命名空間下 
/// 作者:周公 
/// 日期:2008-08-08 
/// 首發地址:http://blog.csdn.Net/zhoufoxcn 
/// </summary> 
public class SendMail2 

    public SendMail2() 
    { 
    }

    /// <summary> 
    /// 發送郵件 
    /// </summary> 
    /// <param name="to">收件人郵件地址</param> 
    /// <param name="from">發件人郵件地址</param> 
    /// <param name="subject">郵件主題</param> 
    /// <param name="body">郵件內容</param> 
    /// <param name="username">登錄smtp主機時用到的用戶名,注意是郵件地址'@'以前的部分</param> 
    /// <param name="passWord">登錄smtp主機時用到的用戶密碼</param> 
    /// <param name="smtpHost">發送郵件用到的smtp主機</param> 
    public void Send(string to, string from, string subject, string body, string userName, string passWord, string smtpHost) 
    { 
        MailAddress from = new MailAddress(from); 
        MailAddress to = new MailAddress(to); 
        MailMessage message = new MailMessage(from, to); 
        message.Subject = subject;//設置郵件主題 
        message.IsBodyHtml = true;//設置郵件正文為Html格式 
        message.Body = body;//設置郵件內容 
        SmtpClient client = new SmtpClIEnt(smtpHost); 
        //設置發送郵件身份驗證方式 
        //注意如果發件人地址是[email protected],則用戶名是abc而不是[email protected] 
        clIEnt.Credentials = new NetworkCredential(userName, passWord); 
        clIEnt.Send(message); 
    } 

在上面的代碼中,主要用到了在.net2.0中新增的兩個類,分別是System.Net.Mail.MailMessage和System.Net.Mail.SmtpClIEnt兩個類,在SMTP身份驗證方面用到了System.Net.NetworkCredential類。

 

需要注意的是:不管是在那種方式下,身份驗證用到的帳號是網頁登錄是用到的帳號,如果你的郵箱地址是[email protected],在登錄mail.163.com郵箱的時候,輸入的帳號是zhou而不是[email protected],身份驗證的時候也是如此。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved