为什么它会发两次邮件

本文关键字:两次 为什么 | 更新日期: 2023-09-27 18:00:25

我有一个程序,可以自动向数据库中的用户发送邮件。我用这个代码把人们带到数据表:

private DataTable verileri_cek() 
{
    consql.Open();
    string kayit = "SELECT * from kisiler where 
        DATEPART(DAY,dogumtarihi)=DATEPART(DAY,GETDATE()) and 
        DATEPART(MONTH,dogumtarihi)=DATEPART(MONTH,GETDATE())";
    SqlCommand komut = new SqlCommand(kayit, consql);
    SqlDataAdapter da = new SqlDataAdapter(komut);
    DataTable dt =new DataTable(); 
    da.Fill(dt);
    consql.Close();
    return dt;
}

然后我想给数据表上的人发邮件。我必须为我的两封不同的电子邮件收到两封电子邮件。但它为一个发送了两次。为什么?这是我发送邮件的部分代码:

private void Saat10()
{
    DataTable dt=verileri_cek();
    if (dt.Rows.Count > 0)
    {
        SmtpClient client = new SmtpClient();
        MailMessage mesaj = new MailMessage();
        for (int i = 0; i < dt.Rows.Count; i++)
        {
            if (dt.Rows[i]["durum"].ToString() == "Akademik")
            {
                mesaj.IsBodyHtml = true;
                mesaj.Subject = "Doğum Günü";
                mesaj.Body = "Sayın Akademik Personelimiz" + dt.Rows[i]["isim"].ToString() + " " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";
             }
             else
             {
                 mesaj.IsBodyHtml = true;
                 mesaj.Subject = "Doğum Günü";
                 mesaj.Body = "Sayın İdari Personelimiz" + " " + dt.Rows[i]["isim"].ToString() + "  " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";
             }
             mesaj.To.Add(dt.Rows[i]["mail"].ToString());
             client.Send(mesaj);
         }
     }
 }

你能帮我吗?

为什么它会发两次邮件

您必须为每个用户创建一个新的MailMessage对象:

 private void Saat10()
 {
    DataTable dt=verileri_cek();
    if (dt.Rows.Count > 0)
    {
        SmtpClient client = new SmtpClient();
        MailMessage mesaj = new MailMessage();
        for (int i = 0; i < dt.Rows.Count; i++)
        {
           mesaj = new MailMessage();
           // all other code
        }
    }
  }

如果我正确理解了您所说的内容,并且您希望为返回表中的每一行都有一条新消息,那么您需要移动:

MailMessage mesaj = new MailMessage();

进入你的For。。循环,而不是在检查是否有行之后。

for (int i = 0; i < dt.Rows.Count; i++)
{
    MailMessage mesaj = new MailMessage();
    //< rest of your code here>
    mesaj.To.Add(dt.Rows[i]["mail"].ToString());
    client.Send(mesaj);
}

首先,我建议每次在实际发送邮件之前打印您的邮件。当然你也可以调试。在您的示例中,您需要在for循环中创建消息。

for (int i = 0; i < dt.Rows.Count; i++)
{
     MailMessage mesaj = new MailMessage();
     if (dt.Rows[i]["durum"].ToString() == "Akademik")
     {
           mesaj.IsBodyHtml = true;
           mesaj.Subject = "Doğum Günü";
           mesaj.Body = "Sayın Akademik Personelimiz" + dt.Rows[i]["isim"].ToString() + " " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";

     }
     else
     {
           mesaj.IsBodyHtml = true;
           mesaj.Subject = "Doğum Günü";
           mesaj.Body = "Sayın İdari Personelimiz" + " " + dt.Rows[i]["isim"].ToString() + "  " + dt.Rows[i]["soyisim"].ToString() + " " + "Doğum Gününüz Kutlu Olsun";
     }
     mesaj.To.Add(dt.Rows[i]["mail"].ToString());
     client.Send(mesaj);
}