无法通过邮件创建和发送动态CSV文件作为附件

时间:2017-02-16 06:21:59

标签: c# email csv stream streamwriter

我正在尝试创建和发送动态csv文件作为邮件附件,但它无法正常工作。我可以发送带附件的邮件,但文件是空的。以下是我的代码:

var notProcessedRecords = FileFTPData.Where(x => x.LastName.StartsWith("9999")).ToList();

      string loggedInUserName = "Administrator";

      try
      {
      MemoryStream stream = new MemoryStream();
      TextWriter writer = new StreamWriter(stream, Encoding.Default);
      StringBuilder sb = new StringBuilder();
      sb.AppendFormat(string.Format("{0}, {1}, {2}, {3}, {4}, {5} ", "FIRSTNAME", "LASTNAME", "USERID", "COMPANYNAME", "EMAIL", "PHONE"));

      foreach (var item in notProcessedRecords)
      {
          sb.AppendLine();
          sb.AppendFormat(string.Format("{0}, {1}, {2}, {3}, {4}, {5} ", item.FirstName, item.LastName, item.UserId, item.CompanyName, item.Email, item.Phone));
      }
      writer.WriteLine(sb);

      MailMessage mail = new MailMessage();
      SmtpClient SmtpServer = new SmtpClient("smtp.gmail.com");
      mail.From = new MailAddress("******@gmail.com");
      mail.To.Add("*******@yahoo.com");
      mail.Subject = "FTP file processing status";
      mail.Body = "<div>Hello " + loggedInUserName + ", </br></br> Following item are restricted from processing, due to some errors. Please check Process description for the same. </br></br>  From, </br>Streben Support </div>";
      mail.IsBodyHtml = true;

      Attachment attachment = new Attachment(stream, new ContentType("text/csv"));
      attachment.Name = "test.csv";
      mail.Attachments.Add(attachment);

      SmtpServer.Port = 587;
      SmtpServer.Credentials = new System.Net.NetworkCredential("******@gmail.com", "******");
      SmtpServer.EnableSsl = true;

      SmtpServer.Send(mail);

      }
      catch(Exception ex)
      {
      }

有人可以帮我纠正这个问题吗?

1 个答案:

答案 0 :(得分:1)

刚刚写完流后,Position属性将设置为流的末尾。此外,编写器中可能仍有一些数据缓冲,但尚未刷新到流中。因此,当从流创建附件时,它将显示为空。要解决这个问题:

// Done writing here //

writer.Flush();
stream.Position = 0;

// Create attachment here //