无法将电子邮件附加到邮件
本文关键字:电子邮件 | 更新日期: 2023-09-27 18:31:23
我正在尝试从sql生成电子邮件列表,然后使用该列表将每个电子邮件地址附加到邮件中。我得到:
指定的字符串不是电子邮件所需的格式 地址。
我做错了什么?此错误发生在Page_Load内的foreach。查看 mailAddress 变量时,它正常显示电子邮件地址,因为它应该"johndoe@gmail.com"
我尝试了一些建议,例如将邮件添加到:
msg.To.Add(new MailAddress(mailAddress.ToString()));
但这没有用。
public class Supervisor
{
public string Email { get; set; }
}
public List<Supervisor> LoadSupervisors(int ID)
{
var listOfEmails = new List<Supervisor>();
using (SqlConnection conn = new SqlConnection(""))
{
SqlCommand cmd = new SqlCommand(@"", conn2);
cmd.Parameters.AddWithValue("@ID", ID);
conn.Open();
SqlDataReader rdr = cmd.ExecuteReader();
while (rdr.Read())
{
var supervisor = new Supervisor();
supervisor.Email = rdr["Email"].ToString();
listOfEmails.Add(supervisor);
}
}
return listOfEmails;
}
protected void Page_Load(object sender, EventArgs e)
{
//----- Bunch of code that isn't related
while (rdr.Read())
{
var listOfEmails = new List<Supervisor>();
listOfEmails = LoadSupervisors(Convert.ToInt32(rdr["UserID"]));
MailMessage msg = new MailMessage();
SmtpClient server = new SmtpClient("");
foreach (var mailAddress in listOfEmails)
{
msg.To.Add(mailAddress.ToString());
}
//----- Bunch of code that isn't related
}
}
我认为你应该得到你的mailAddress
而不是它本身.Email
属性。因为mailAddress
是Supervisor
,不是string
什么的。
尝试为;
msg.To.Add(mailAddress.Email.ToString());
但是,当然,我们对Email
类型一无所知,我假设它以字符串形式返回此邮件地址,因为您说您在调试器或其他东西上看到它。