用于将邮件发送到多个电子邮件地址以及附件和获取传递的代码

时间:2012-12-19 07:32:05

标签: c# asp.net .net

我需要一个最好的(性能问题)代码,用于将邮件发送到带有附件的多个电子邮件地址并在c#中获取

2 个答案:

答案 0 :(得分:3)

用c#发送邮件:

Sending Email with attachment in ASP.NET using SMTP Server

MailMessage有一个DeliveryNotificationOptions property,设置如下:

messagetest .DeliveryNotificationOptions = DeliveryN otificationOptions.OnSuccess;

答案 1 :(得分:2)

以下是从CSV文件中读取名称,电子邮件地址的代码,以便它可以发送到这些地址。它涉及许多功能。每一个都很清楚。

//Declare these two variables global in the form, class
MailMessage message;//= new MailMessage()
SmtpClient smtpClient;//= new SmtpClient()

//A function that will read data from CSV File into List and will create a     DataTable 
public DataTable maketable()
    {
        string path = this.Server.MapPath("app_data");
        path += "\\employeelist.csv";
        List<string[]> testParse =
          parseCSV(path);
        DataTable newTable = new DataTable();
        foreach (string column in testParse[0])
        {
            newTable.Columns.Add();
        }

        foreach (string[] row in testParse)
        {
            newTable.Rows.Add(row);
        }
        return newTable;
    }
//This Functions Actually reads the CSV file and make list
public List<string[]> parseCSV(string path)
    {
        List<string[]> parsedData = new List<string[]>();
        try
        {
            using (StreamReader readFile = new StreamReader(path))
            {
                string line;
                string[] row;
                while ((line = readFile.ReadLine()) != null)
                {
                    row = line.Split(',');
                    parsedData.Add(row);
                }
            }
        }
        catch (Exception e)
        {
            parent.list.Items.Add(e.Message);
        }
        return parsedData;
    }

//I have called below function with given subject and body text as a string at any place.. either in button_click event or any other place
SendAttendanceWithAttachment(email_subject, body);
// Now the body of SendAttendanceWithAttachment(.....);
void SendAttendanceWithAttachment(string subject, string body)
    {
        string FileAbsolutePath = "C:\\att\\"; // where the directory is containing files for attachment
        string FileName = "";
        Attachment attach;
        //OPen CSV File Read all contact and then send one by one. 
        smtpClient = new SmtpClient();
        smtpClient.Host = "<smtp host>";//like for google : ssl://smtp.gmail.com
        smtpClient.Port = <int>;// port number for google 465
        smtpClient.UseDefaultCredentials = true;
        smtpClient.Credentials = new System.Net.NetworkCredential("<gmail address>", "<password>");

        MailAddress fromAddress = new MailAddress("<sender email address>");
        dt = maketable();
        try
        {
            add_item("Weekly attendance Sending starts....");
            for (int i = 0; i < dt.Rows.Count; i++)//dt.Rows.Count
            {
                message = new MailMessage();
                if (dt.Rows[i][1].ToString() == string.Empty)
                {
                    continue;
                }
                else
                {
                    FileName = FileAbsolutePath + dt.Rows[i][0].ToString() + ".csv";
                    if (File.Exists(FileName))
                    {
                        attach = new Attachment(FileName);
                        //Add in data
                        message.To.Add(dt.Rows[i][1].ToString());
                        message.Subject = subject;
                        message.IsBodyHtml = true;
                        message.Body = body;
                        message.From = fromAddress;
                        message.Attachments.Add(attach);
                        //add_item("Sending Message " + (i+1) + " of " + dt.Rows.Count + " to : " + dt.Rows[i][0].ToString());
                        SendMail(message, smtpClient);
                        //add_item("Email Sent to :" + dt.Rows[i][0].ToString());
                    }
                }
            }
            //add_item("Weekly attendance Sent to all..");
        }
        catch (System.Exception e)
        {
            //parent.list.Items.Add(e.Message);
        }
//Finally the SendMail()...
public void SendMail(MailMessage message, SmtpClient smtpClient)
    {
        try
        {
            smtpClient.Send(message);
        }
        catch (Exception ex)
        {
            //parent.list.Items.Add(ex.Message);
        }
    }

它是一个完整的过程,您如何从CSV文件中读取,将地址添加到列表,然后添加到DataTable,然后使用文件附件和发送来编写电子邮件。希望你能从中受益。