无法将电子邮件附加到MailMessage

时间:2016-01-21 15:02:01

标签: c# asp.net list mailmessage

我正在尝试从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
   }
}

1 个答案:

答案 0 :(得分:1)

我认为你应该获得DataService<Client>的{​​{1}}属性而不是自己。因为For(typeof(IDataService<OtherEntity>)).Use(typeof(DataService<OtherEntity>)); .Email,而不是mailAddress或其他。

试试;

mailAddress

但是,当然,我们对Supervisor类型一无所知,我认为它会将此邮件地址作为字符串返回,因为您说您在调试器上看到了它。