我有一个gridview
包含客户姓名、电子邮件、日期等的显示数据SQL table
。它包含checkboxes
选择所有行。单击标题checkbox
时,checkboxes
也会检查行中的行(工作正常)。gridview
绑定代码:
private void BindGrid()
{
using (var db = new DatabaseHelper())
{
using (var ds = db.ExecDataSet(Queries.BindReminderEmailGrid))
{
Grid.DataSource = ds;
}
}
Grid.DataBind();
}
if(!IsPostBack){}
在里面调用这个代码PageLoad
。
我有一个点击按钮,我正在向所有选中的行发送电子邮件:
protected void btnSendEmailToAll_Click(object sender, EventArgs e)
{
string Name = "";
string username = Master.User;
CheckBox ChkBoxHeader = (CheckBox)Grid.HeaderRow.FindControl("chkboxSelectAll");
//Create a temporary DataTable
DataTable dtCustomers = new DataTable();
dtCustomers.Columns.AddRange(new DataColumn[3] { new DataColumn("name", typeof(string)),
new DataColumn("email",typeof(string)), new DataColumn("EmailSentOn",typeof(string)) });
//Copy the Checked Rows to DataTable
foreach (GridViewRow row in Grid.Rows)
{
// Only look in data rows, ignore header and footer rows
if (row.RowType == DataControlRowType.DataRow)
{
CheckBox ChkBoxRows = (CheckBox)row.FindControl("chkrow");
if (ChkBoxHeader.Checked == true)
{
ChkBoxRows.Checked = true;
}
if (ChkBoxRows.Checked == true)
{
Name = (row.FindControl("lblname") as Label).Text.ToLower();
dtCustomers.Rows.Add(Name, (row.FindControl("lblemail") as Label).Text, (row.FindControl("lblEmailsentOn") as Label).Text);
var id = Grid.DataKeys[row.RowIndex].Value;
using (var db = new DatabaseHelper())
{
db.ExecNonQuery(Queries.UpdateReminderEmailSentData, "@RW", id);
}
}
}
}
string subject = "Email Subject";
//Using Parallel Multi-Threading send multiple bulk email.
Parallel.ForEach(dtCustomers.AsEnumerable(), row =>
{
string body = this.PopulateBody(Name, row["EmailSentOn"].ToString(), username);
SendHtmlFormattedEmail(row["email"].ToString(), subject, body.ToString());
});
ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('Email Sent Successfully')", true);
BindGrid();
}
SendHTMLFormatedEmail 函数:
private void SendHtmlFormattedEmail(string recepientEmail, string subject, string ShowBody)
{
if (recepientEmail != "")
{
var smtp = new SmtpClient()
{
Host = WebConfigurationManager.AppSettings["Host"],
EnableSsl = Convert.ToBoolean(WebConfigurationManager.AppSettings["EnableSsl"]),
UseDefaultCredentials = true,
Credentials = new System.Net.NetworkCredential(WebConfigurationManager.AppSettings["UserName"], WebConfigurationManager.AppSettings["Password"]),
Port = int.Parse(WebConfigurationManager.AppSettings["Port"])
};
using (MailMessage mailMessage = new MailMessage())
{
mailMessage.From = new MailAddress(WebConfigurationManager.AppSettings["UserName"], "Email From Us");
mailMessage.Subject = subject;
mailMessage.Body = ShowBody;
mailMessage.IsBodyHtml = true;
mailMessage.To.Add(new MailAddress(recepientEmail));
smtp.Send(mailMessage);
}
}
else
{
ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alertMessage", "alert('Please enter a valid email address')", true);
}
}
一切似乎都很好,但问题是它只向少数客户发送电子邮件。例如,今天我向大约 56 位客户发送电子邮件,但实际上只发送了 11 封电子邮件。
编辑后出现以下错误:
服务不可用,正在关闭传输通道。服务器响应为:4.7.0 临时系统问题。稍后再试 (WS)。x4sm1307841pfb.101 - gsmtp
并仅向 12 位客户发送电子邮件,但名称相同:(
我无法追踪它出了什么问题。请帮助我如何解决它。提前致谢..!!