顯示具有 附加檔案 標籤的文章。 顯示所有文章
顯示具有 附加檔案 標籤的文章。 顯示所有文章

2022年10月23日 星期日

V20107D - Email - 附加檔案 - xlsx 檔案 - V30702E - 單純Email,未附加檔案

 目的: V20107D - Email 附加檔案 - *.xlsx 檔案

處理說明: 1>產生 *.xlsx 檔案 , 並產生網路路徑檔案
                      Workbook wk = new Workbook();
                      Worksheet sheet1 = wk.Worksheets[0];//獲取第一個工作表
                                   :
                      sheet1.Range[myfunc.GetExcelPos(0, i + 1)].Text = reader["DEPID"].ToString();
                                 :                       
                      // 取得實實的路徑            
                         string documentPath = HttpContext.Current.Server.MapPath("~") + "document\\";                                    string FileName1 = documentPath + par_FName;
                         wk.SaveToFile(FileName1, FileFormat.Version2007);
                
                  2>Email 處理: 附加檔案 - 以完整檔案路徑檔名 , 附加檔案
                      MailMessage ChkMail = new MailMessage();
                      ChkMail.To.add("xxx@xxxx") ;
                     string mail_from = "tlsapp@ms.aidc.com.tw";
                ChkMail.From = new MailAddress(mail_from, "AMM系統", System.Text.Encoding.UTF8);
                string subject = "AMM V20107 工作步序資料維護 - 工時不完整(=0)";
                string content = "附檔內的件號工作步序資料不完整<br>"
                                          + "請至 AMM V20107維護工作步序資料<br>";

ContentType ct = new ContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
                Attachment attm = new Attachment(Tmp_FName, ct);
                ChkMail.Attachments.Add(attm);

                sendMail(subject, content, ChkMail);  //baseAPIController




1>*.js
//[MAIL通知]鈕
function MAILNotifyBtn_click() {
var np = {};
np = {};
Ext.Ajax.request({
url: '../../api/V20107DAPI/DoMAIL',

method: 'POST',
async: false,
//standardSubmit: true, //若要傳送檔案至前端, standardSubmit必需設為 true
params: np,
success: function (response, opts) {
var Tmp_Obj = Ext.decode(response.responseText);
if (Tmp_Obj["success"] == false) {
var Tmp_Rtn_Msg = "EMAIL通知人員失敗!!<br>"
+ "請檢核<br>"
+ Tmp_Obj["Rtn_Msg"];
mywarnalert(Tmp_Rtn_Msg);
return;
}
else {
var Tmp_Rtn_Msg = "EMAIL通知人員成功!!<br>";
mysuccessalert(Tmp_Rtn_Msg);
}
}
});
} // end of function MAILNotifyBtn_click() {


2>*.cs
// [MAIL通知] - DoMAIL

        [HttpPost]
        public HttpResponseMessage DoMAIL()
        {
            //取得參數值
            var c = HttpContext.Current;
            NameValueCollection nvc = c.Request.Form;
            
            string Tmp_USERID = LoginUserModel.LoginUserId;            
            string Tmp_RtnMsg = "";
            string To_Adr = "";
            string n = funId + "_DoMAIL";
            OracleConnection conn = new OracleConnection(DBService.ConnectionString(DBLINK));
            OracleCommand cmd = new OracleCommand();
            OracleDataReader reader;

            var response = Request.CreateResponse();
            MailMessage ChkMail = new MailMessage();
            try
            {
                conn.Open();
                conn.ClientInfo = User.Identity.Name;
                conn.ModuleName = BaseSYS + "_" + BaseMODID;
                conn.ActionName = ActionName;
                cmd.BindByName = true;
                cmd.Connection = conn;
                string Tmp_Sql;
                int Tmp_cnt=0;
                Tmp_Sql = "  SELECT COUNT(*)  "
                                +"   FROM   AMM_WKSTP A, AMM_WKSTPD B  "
                                +"   WHERE A.MITM = B.MITM  "
                                +"   AND      (B.WHR = '0' OR B.WHR IS NULL)  "
                                +"  AND        SUBSTR(DEPID,1,2) = ( SELECT SUBSTR(DEPID, 1, 2)  "
                                +                                                        "   FROM   HR_EMPLYM  "
                                +                                                        "  WHERE  EMPLYID = "+myfunc.AA(Tmp_USERID)+") ";
                Tmp_cnt = int.Parse(myfunc.SqlValue(Tmp_Sql));
                if (Tmp_cnt==0)
                {
                    Tmp_RtnMsg = "目前登入使用者(" + Tmp_USERID + ")的部門相關工作步序資料<br>"
                                             + "工時資料均完整 ( 工時>0 ) <br>"
                                             + "不需 MAIL 通知相關人員";                                             
                    response.Content = new StringContent("{'success': false,'Rtn_Msg':'" + Tmp_RtnMsg + "'}");    // 回應內容
                    return response;
                }
                //填寫 Email.From, To, subject, BODY
                Tmp_Sql= "  SELECT A.EMPLYID,B.NOTES_MAIL  "
                               +"   FROM AMM_MAILIST A, HR_EMPLYM B  "
                               +"   WHERE A.EMPLYID = B.EMPLYID  "
                               +"   AND A.DEPID = ( SELECT   SUBSTR(DEPID, 1, 2)  "
                               +                               "   FROM    HR_EMPLYM  "
                               +                               "   WHERE  EMPLYID ="+myfunc.AA(Tmp_USERID)+" ) ";
                cmd.CommandText = Tmp_Sql;
                reader = cmd.ExecuteReader();
                if (reader.HasRows)
                {
                    while (reader.Read())
                    {
                        ChkMail.To.Add(reader["NOTES_MAIL"].ToString());
                    }
                };                
                string mail_from = "tlsapp@ms.aidc.com.tw";
                ChkMail.From = new MailAddress(mail_from, "AMM系統", System.Text.Encoding.UTF8);//發送者 
                string subject = "AMM V20107 工作步序資料維護 - 工時不完整(=0)";
                string content = "附檔內的件號工作步序資料不完整<br>"
                                          + "請至 AMM V20107維護工作步序資料<br>";
                //產生 *.xls 檔案
                string Tmp_FName = "V20107工作步序資料維護.xlsx";            
                Tmp_FName = ExportFile1(Tmp_FName);

                //附加檔案處理
                ContentType ct = new ContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
                Attachment attm = new Attachment(Tmp_FName, ct);
                ChkMail.Attachments.Add(attm);


                sendMail(subject, content, ChkMail);
                response.StatusCode = HttpStatusCode.OK;
                Tmp_RtnMsg = "已 Email 通知相關人員 !!  <br>";
                response.Content = new StringContent("{'success': true,'Rtn_Msg':'" + Tmp_RtnMsg + "'}");    // 回應內容
                return response;
                //excuteSQLTran
            }  //try
            catch (Exception e)
            {
                string Tmp_msg;
                Tmp_msg = myfunc.Get1ORA(e.Message);
                Tmp_RtnMsg = "Email 通知失敗<br>"
                                         + Tmp_msg;
                response.Content = new StringContent("{'success': false,'Rtn_Msg':'" + Tmp_RtnMsg + "'}");    // 回應內容
                return response;
            }
            finally
            {
                conn.Close();
            }
        }  // end of DoMAIL


//產生 Email 附件檔案  , 傳回檔名
        public string ExportFile1(string par_FName)
        {
            OracleConnection conn = new OracleConnection(DBService.ConnectionString(DBLINK));
            OracleCommand cmd = new OracleCommand();
            OracleDataReader reader;
            string Tmp_USERID = LoginUserModel.LoginUserId;
            Workbook wk = new Workbook();
            MemoryStream stream = new MemoryStream();
            try
            {
                conn.Open();
                conn.ClientInfo = User.Identity.Name;
                conn.ModuleName = BaseSYS + "_" + BaseMODID;
                conn.ActionName = ActionName;
                cmd.BindByName = true;
                cmd.Connection = conn;
                string Tmp_Sql;
                //wk = new Workbook();
                Worksheet sheet1 = wk.Worksheets[0];//獲取第一個工作表
                string[] outFieldArray = { "部門編號", "工作中心", "EO_ECN", "情況處理碼", "件號",
                                                             "中文名稱","英文名稱","料號","建檔人員","建檔日期"};
                for (int i = 0; i < outFieldArray.Length; i++)
                {
                    sheet1.Range[myfunc.GetExcelPos(i, 0)].Text = outFieldArray[i];
                }
                //填寫 Email.From, To, subject, BODY
                Tmp_Sql = "  SELECT  DISTINCT A.DEPID , A.WC , A.ECNO , A.CNDPROCCODE , A.PN , "
                                                + "  A.CNM , A.ENM , A.NSN , A.ENER , A.ENDT  "
                                 + " FROM     AMM_WKSTP A, AMM_WKSTPD B  "
                                + "  WHERE   A.MITM = B.MITM  "
                                + " AND        (B.WHR = '0' OR B.WHR IS NULL)   "
                               + "  AND        SUBSTR(DEPID,1,2) = (  SELECT SUBSTR(DEPID, 1, 2)  "
                                                                                        + "   FROM HR_EMPLYM  "
                                                                                        + "   WHERE EMPLYID = " + myfunc.AA(Tmp_USERID) + " ) ";
                cmd.CommandText = Tmp_Sql;
                reader = cmd.ExecuteReader();
                if (reader.HasRows)
                {
                    int i = 0;
                    while (reader.Read())
                    {
                        sheet1.Range[myfunc.GetExcelPos(0, i + 1)].Text = reader["DEPID"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(1, i + 1)].Text = reader["WC"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(2, i + 1)].Text = reader["ECNO"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(3, i + 1)].Text = reader["CNDPROCCODE"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(4, i + 1)].Text = reader["PN"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(5, i + 1)].Text = reader["CNM"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(6, i + 1)].Text = reader["ENM"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(7, i + 1)].Text = reader["NSN"].ToString();
                        sheet1.Range[myfunc.GetExcelPos(8, i + 1)].Text = reader["ENER"].ToString();
                        if (!myfunc.checkisnull(reader["ENDT"].ToString()))
                        { sheet1.Range[myfunc.GetExcelPos(9, i + 1)].Text = String.Format("{0:yyyy/MM/dd}", DateTime.Parse(reader["ENDT"].ToString())); };
                        i = i + 1;
                    }  // end  of while (reader.Read())
                } // end of  if reader.HasRows
                sheet1.AllocatedRange.AutoFitColumns();
                wk.SaveToStream(stream, FileFormat.Version2007);
                string documentPath = HttpContext.Current.Server.MapPath("~") + "document\\";  // 取得實實的路徑            
                string FileName1 = documentPath + par_FName;
                wk.SaveToFile(FileName1, FileFormat.Version2007);
                return FileName1;
            }// end of try{
            finally
            {
                conn.Close();
                wk.Dispose();
            }
        }  // end of  ExportFile1

2>V30702E.cs
    Tmp_Sql = "  SELECT  * "
                   + "   FROM    AMM_DSPHCAR   "
                   + "  WHERE   TASKNO=" + myfunc.AA(Tmp_TASKNO);
    Tmp_dt0 = myfunc.SqlOpen(Tmp_dt0, Tmp_Sql);
    MailMessage ChkMail = new MailMessage();
    string mail_from = "tlsapp@ms.aidc.com.tw";
    ChkMail.From = new MailAddress(mail_from, "AMM系統", System.Text.Encoding.UTF8);
    Tmp_Sql = "  SELECT   B.NOTES_MAIL  "
                   + "   FROM    HR_EMPLYM B  "
                   + "   WHERE  B.EMPLYID = " + myfunc.AA(Tmp_dt0.Rows[0]["RQMAN"].ToString());
    string Tmp_toMail = myfunc.SqlValue(Tmp_Sql);
    ChkMail.To.Add(Tmp_toMail);                                
    string subject = "地裝派遣單剔退通知  - 派遣單號("+ Tmp_TASKNO+")";
    string content = "地裝派遣單已剔退<br>"
                           + "派遣單號:" + Tmp_TASKNO + "<br>"
                           + "請至系統修正後再提出!!<br>"
                           +"<br>"
                           + "詳細內容如下:<br>"
                           + "派遣單號:" + myfunc.AA(Tmp_TASKNO) + "<br>"
                           + "需求人:" + myfunc.AA(Tmp_dt0.Rows[0]["RQMAN"].ToString()) + "<br>"
                           + "需求日期:" + myfunc.AA(Tmp_dt0.Rows[0]["RQDT"].ToString()) + "<br>"
                           + "需求單位:" + myfunc.AA(Tmp_dt0.Rows[0]["RQDEP"].ToString()) + "<br>"
                           + "起點:" + myfunc.AA(Tmp_dt0.Rows[0]["STLC"].ToString()) + "<br>"
                           + "迄點:" + myfunc.AA(Tmp_dt0.Rows[0]["EDLC"].ToString()) + "<br>"
                    + "工作簡述:" + myfunc.AA(Tmp_dt0.Rows[0]["TASKREMARK"].ToString()) + "<br>"
                            + "剔退原因:" + myfunc.AA(Tmp_DELCAUSE) + "<br>"
                            + "剔退人員:" + myfunc.AA(Tmp_DELMAN) + "<br>";
                sendMail(subject, content, ChkMail);
       Tmp_RtnMsg = "地裝派遣單號(" + Tmp_TASKNO + ")已[剔退]完成  &  Email 原需求人員 !!";

2022年10月21日 星期五

Email 用法說明 - MailMessage, SMTP - 附加檔案的用法: Attachments

目的:  Web  Email  用法說明

從 .Net2.0 開始, System.Net.Mail 命名空間提供開發者建立及傳送郵件訊息的相關方法。

  • MailMessage
    這個類別是用來建立電子郵件。支援簡單的純文字、HTML格式的電子郵件訊息、以及不同檢視方式、編碼標準及附加檔。
  • SmtpClient
    這個類別是用來寄送電子郵件。支援匿名網路連結、使用者驗證及SSL加密,另外也可以非同步寄送電子郵件,且允許使用者在寄送完成前取消寄送。

MailMessage 類別

MailMessage 的建構子

public MailMessage()
public MailMessage(string from,string to)
public MailMessage(string from,string to,string subject,string body)
public MailMessage(MailAddress from,MailAddress to)

MailMessage 的屬性

  • Subject :取得或設定這個電子郵件訊息的主旨
  • Body :取得或設定訊息主體。
  • IsBodyHtml :取得或設定值,指出郵件訊息主體是否採用 Html 格式。
  • From :寄件者。
  • To :收件者。
  • CC :副本收件者。
  • Bcc :密件副本收件者。
  • BodyEncoding :主體內容所用的編碼方式。
  • SubjectEncoding :主旨內容所用的編碼方式。
  • Attachments :取得附件集合。
  • AlternateViews :訊息主體的替代格式。

SmtpClient 類別

SmtpClient 的建構子

public SmtpClient();
public SmtpClient(string host);
public SmtpClient(string host, int port);

SmtpClient 的屬性

  • ClientCertificates :
  • EnableSsl :
  • Host :SMTP 交易的主機名稱或 IP 位址。
  • Port :SMTP 交易的連接埠。
  • Timeout : Send 呼叫逾時的時間。

SmtpClient 的方法

  • Send :傳送電子郵件訊息給 SMTP 伺服器進行傳遞。在傳送訊息時,會封鎖這些方法。
  • OnSendCompleted :引發 SendCompleted 事件。
  • SendAsync :傳送電子郵件訊息。 這些方法不會封鎖呼叫執行緒。
  • SendAsyncCancel :取消傳送電子郵件訊息的非同步作業。

範例一:示範建立 MailMessage 的相關方法

//建立一個MailMessage,同時指明 MailForm, MailTo, Subject, Body
MailMessage mail = new MailMessage ("jane@contoso.com", "ben@contoso.com", "Mail Subject", "Mail Body Test");

//寄件者, 收件者, 主旨, 本文內容
MailMessage mail = new MailMessage();
mail.From = new MailAddress("jane@contoso.com", "DisplayName"); //email, 顯示名稱

mail.To.Add(new MailAddress("ben.test@contoso.com", "ben test"));
mail.To.Add(new MailAddress("ben test<ben.test@contoso.com>"));     //使用角括弧,可使用一個參數同時包含顯示名稱和email 
mail.To.Add("ben test<ben.test@contoso.com>");                      //這樣使用也行。 but..中文..(請看下面注意說明)
            
mail.Subject = "Mail Subject";
mail.Body = "Mail Body Test";

//副本、密件副本
mail.CC.Add(new MailAddress("ben4@contoso.com", "ben4"));
mail.Bcc.Add(new MailAddress("ben3@contoso.com", "ben3"));

//DeliveryNotificationOptions:通知狀態 OnSuccess, OnFailure, Delay, None, Never
//ReplyTo:設定一個回覆地址
//Priority:設定電子郵件的優先順序

mail.DeliveryNotificationOptions = DeliveryNotificationOptions.OnFailure | DeliveryNotificationOptions.OnSuccess;
mail.ReplyTo = new MailAddress("ben5@contoso.com", "ben5");
mail.Priority = MailPriority.High;

//html編碼  
mail.Body = "<html><body><h1>Picture</h1><br><img src=\"cid:Pic1\"></body></html>";
mail.IsBodyHtml = true;
mail.BodyEncoding = Encoding.UTF8; 

注意:若顯示名稱含中文時

當使用 mail.To.Add("ben test<ben.test@contoso.com>"); 這個方式加入email時,
若顯示名稱為中文時會產生錯誤,例如:mail.To.Add("測試<ben.test@contoso.com>"); 會跳出"指定字串不在電子郵件地址的必要表單中"的錯誤訊息.
只能使用這個方式 mail.To.Add(new MailAddress("測試<ben.test@contoso.com>"))
或將顯示名稱放在第二個參數
mail.To.Add(new MailAddress("ben.test@contoso.com", "測試"));

範例二:使用 SmtpClient 發送 MailMessage 的相關方法

SmtpClient client = new SmtpClient("smpt.gmail.com");   //建立 SMTP ,並指定 SMTP Server
client.Credentials = new System.Net.NetworkCredential("user", "pwd");   //驗證寄件者
client.EnableSsl = true;                                                //是否啟用 SSL
client.Port = 25;                                                       //指定 SMTP 交易連接埠
SendMail(client, mail);
//SmtpClient Smtp = new SmtpClient();   //建立SMTP連線  
//Smtp.Send(mail);   //發送

private void SendMail(SmtpClient client, MailMessage mail)
{
    try
    {
        client.Send(mail);  //寄送郵件
        MessageBox.Show("email send");
    }
    //Handle Mail Exceptions
    catch (InvalidOperationException exInvalidOperation)            //沒有指定 SMTP Server
    {
        MessageBox.Show(exInvalidOperation.Message.ToString());   
    }
    catch (SmtpFailedRecipientException exSmtpFailedRecipient)      //指定錯誤的收件者
    {
        MessageBox.Show(exSmtpFailedRecipient.Message.ToString());
    }
    catch (SmtpException exSmtp)                                    //找不到 SMTP 或 其他的例外錯誤
    {
        MessageBox.Show(exSmtp.Message.ToString());
    }
    catch (Exception ex)
    {
        MessageBox.Show(ex.Message.ToString());
    }
}

範例三:附加檔案

呼叫 MailMessage.Attachments 可取得附件的集合 AttachmentCollection 物件。 其組成項目為 Attachment 物件,可以透過該集合的 Add 方法加入新的項目。

MailMessage mailmessage = new MailMessage();

mailmessage.From = new MailAddress(txtMailFrom.Text);
mailmessage.To.Add(new MailAddress(txtMailTo.Text));
mailmessage.Subject = txtSubject.Text;
mailmessage.Body = txtBody.Text;
mailmessage.IsBodyHtml = cbHTML.Checked;

SmtpClient smtpclient = new SmtpClient(cbSMTP.Text);
smtpclient.Credentials = new System.Net.NetworkCredential(txtAccount.Text, txtPassword.Text);
smtpclient.EnableSsl = cbSSL.Checked;
smtpclient.Port = int.Parse(txtSmtpPort.Text);

string sFilePath = @"D:\MCTS\MCTS2011\Practice\Practice\bin\Debug\cloud.jpg";
Attachment attachment = new Attachment(sFilePath);
mailmessage.Attachments.Add(attachment);

SendMail(smtpclient, mailmessage);

Attachment 有好幾個建構子,其中一個包含一個 stream ,也就是可以將 stream 變成附件形式寄出。

// create SmtpClient
SmtpClient smtpclient = new SmtpClient(cbSMTP.Text);
smtpclient.Credentials = new System.Net.NetworkCredential(txtAccount.Text, txtPassword.Text);
smtpclient.EnableSsl = cbSSL.Checked;
smtpclient.Port = int.Parse(txtSmtpPort.Text);

// create Attachment
string sContent = "將資料流轉成附加檔案";
byte[] byteArray = Encoding.UTF8.GetBytes(sContent);
MemoryStream stream = new MemoryStream(byteArray);
Attachment attm = new Attachment(stream, "myfile.txt", MediaTypeNames.Text.Plain);

// create MailMessage
MailMessage mailmessage = new MailMessage();
mailmessage.From = new MailAddress(txtMailFrom.Text);
mailmessage.To.Add(new MailAddress(txtMailTo.Text));
mailmessage.Subject = txtSubject.Text;
mailmessage.Attachments.Add(attm);

// Send
SendMail(smtpclient, mailmessage);

範例四:指定不同格式的電子郵件

因應某些收件者無法顯示 HTML 內容,也可以同時提供純文字和 HTML 版本的郵件內容。

  • AlternateView 類別:用來建立不同格式的郵件複本。
  • MediaTypeNames 類別:指定郵件複本的媒體類型資訊。{Html,Plain,RichText,XML...}
// 設定一個HTML格式的 AlternateView 
string htmlBody = "<body><html>This message support <b>HTML</b></html></body>";
AlternateView viewHtml = AlternateView.CreateAlternateViewFromString(htmlBody, null, MediaTypeNames.Text.Html);
avHtml.LinkedResources.Add(pic1);

// 設定一個文字格式的 AlternateView
string textBody = "This message doesn't support HTML";
AlternateView viewPlain = AlternateView.CreateAlternateViewFromString(textBody, null, MediaTypeNames.Text.Plain);

// 使用 alternate views 加入訊息主體,替代 MailMessage.Body
mailmessage.AlternateViews.Add(viewHtml);
mailmessage.AlternateViews.Add(viewPlain);

SendMail(smtpclient, mailmessage);

範例五:內嵌檔案(1)

透過 LinkedResource 類別,可用來建立資源連結物件,並將該物件加入 Html 格式的 AlternateView 物件中。

給定每個 LinkedResource 一個唯一的 ContentId ,再將這個 ContentId 套用到 <img> 標籤的 cid 屬性的值。

// 設定連結資源檔
string sFilePath = @"D:\MCTS\MCTS2011\Practice\PracticeMCTS\bin\Debug\cloud.jpg";
LinkedResource resource1 = new LinkedResource(sFilePath, MediaTypeNames.Image.Jpeg);
resource1.ContentId = "resource_id_1";      //定義這個資源的 ContentID。

// 設定一個HTML格式的本文內容,並加入連結資源檔
string htmlBody = @"
<html><body>

<h1>資源內嵌</h1>
<img src=""cid:resource_id_1"" />

</body></html>";

AlternateView viewHtml = AlternateView.CreateAlternateViewFromString(htmlBody, null, MediaTypeNames.Text.Html);
viewHtml.LinkedResources.Add(resource1);

// 使用 alternate views 替代 MailMessage.Body
mailmessage.AlternateViews.Add(viewHtml);

SendMail(smtpclient, mailmessage);

範例六:內嵌檔案(2)

<img> 標籤中的 src 屬性,其值要等於 Attachment.Name 。

// 設定附件檔
string sFilePath2 = @"D:\MCTS\MCTS2011\Practice\PracticeMCTS\bin\Debug\cloud.jpg";
Attachment attm = new Attachment(sFilePath2);
attm.Name = Path.GetFileName(sFilePath2);
attm.NameEncoding = Encoding.GetEncoding("utf-8");
attm.TransferEncoding = TransferEncoding.Base64;

// 設定該附件為一個內嵌附件(Inline Attachment)
attm.ContentDisposition.Inline = true;                                      //附件中的內容是以內嵌方式呈現為電子郵件主體的一部分,則為 true
attm.ContentDisposition.DispositionType = DispositionTypeNames.Inline;      //附件類型 => 將附件顯示為電子郵件訊息主體的一部分
mailmessage.Attachments.Add(attm);

// 設定一個HTML格式的本文內容,並加入附件檔 
// img 標籤中的 src 屬性,其值要等於 Attachment.Name
string htmlBody = @"
<html><body>

<h3>附件內嵌(Inline Attachment)</h3>
<img src=""cloud.jpg"" />                       

</body></html>";
mailmessage.Body = htmlBody;

SendMail(smtpclient, mailmessage);

範例七:非同步傳送電子郵件

SmtpClient sc ;
private void btnSendAsync_Click(object sender, EventArgs e)
{
    MailMessage mail = new MailMessage();

    mail.From = new MailAddress(txtMailFrom.Text);
    mail.To.Add(new MailAddress(txtMailTo.Text));
    mail.Subject = txtSubject.Text;
    mail.Body = txtBody.Text;
    mail.IsBodyHtml = cbHTML.Checked;

    sc = new SmtpClient(cbSMTP.Text);
    sc.Credentials = new System.Net.NetworkCredential(txtAccount.Text, txtPassword.Text);
    sc.EnableSsl = cbSSL.Checked;
    sc.Port = int.Parse(txtSmtpPort.Text);

    string sFilePath = @"D:\MCTS\MCTS2011\Practice\Practice\bin\Debug\cloud.jpg";
    Attachment attm = new Attachment(sFilePath);
    mail.Attachments.Add(attm);

    sc.SendCompleted += new SendCompletedEventHandler(SendCompleted);
    sc.SendAsync(mail, null);
}

private void btnCancel_Click(object sender, EventArgs e)
{
    sc.SendAsyncCancel();
}

private void SendCompleted(object sender, AsyncCompletedEventArgs e)
{
    if (e.Cancelled)
        MessageBox.Show("Message Cancelled");
    else
    {
        if (e.Error != null)
            MessageBox.Show("Error : " + e.Error.ToString());
        else
            MessageBox.Show("Send Completed");
    }
}