发送List<比;邮件中带有正文的值- SMTP服务器
本文关键字:正文 服务器 SMTP List 发送 | 更新日期: 2023-09-27 18:02:17
我必须通过SMTP
服务器发送邮件。我可以用单个值发送它。但是,我想发送List<>
值作为表格式或其他结构的消息体。我的代码如下:
MailMessage mailObj = new MailMessage("abc@gmail.com", "xyz@gmail.com", "Reg : send mail",
"Emp Name :" + "Emp1" + Environment.NewLine + "Date From : " + Mon + "Date To : " + Fri);
SmtpClient SMTPServer = new SmtpClient("smtp.gmail.com", ***);
SMTPServer.Host = "smtp.gmail.com";
SMTPServer.EnableSsl = true;
SMTPServer.Timeout = 200000;
SMTPServer.Credentials = new System.Net.NetworkCredential("asd@gmail.com", "******");
SMTPServer.Send(mailObj);
我的值列表如下:
List<TimesheetValues> mailBody = new SampleDAO().GetDataForMail(dt1, satDate);
我如何包含这个List<>
值与正文和发送?
我尝试如下:
List<TimesheetValues> Msg = new List<TimesheetValues>(); string strMsg = ""; int n=1;
foreach(var item in mailBody)
{
strMsg = strMsg + "<table><tr><td>" + n + "</td><td>" + item.Project_Name + "</td><td>" + item.Task_Name + "</td><td>" + item.Notes + "</td><td>" + item.Hrs_Worked + "</td></tr></table>";
n++;
}
strMsg = strMsg + "</br>";
MailMessage mailObj = new MailMessage("abc123@gmail.com", "xyz123@gmail.com", "Reg : Timesheet",
"Emp Name :" + "Emp1" + Environment.NewLine + "Date From : " + Mon + "Date To : " + Fri);
mailObj.Body = "Emp Name : " + "Emp1" + Environment.NewLine + "Date From : " + Date2 + " Date To : " + Date6 + Environment.NewLine + strMsg;
现在我得到了所有的记录,但我在记录中有trtd标签,而不是显示为表。我怎样才能做到这一点?
谁能帮助克服这个…
如果您想再次将字符串读入列表,那么序列化是更好的选择。
using Newtonsoft.Json;
var json = JsonConvert.SerializeObject(yourList);
mailObj.Body = json;
你也可以在另一边反序列化:
List<string> g = JsonConvert.DeserializeObject<List<string>>(body);
我尝试如下:
string strMsg = ""
strMsg = timsheetMail + " <table style='"border-collapse:collapse; text-align:center;'" border='"1'"><tr><td> Date </td><td> Working Hours </td><td> Task </td><td>Comments</td></tr>";
List<TimesheetValues> Msg = new List<TimesheetValues>(); int n=1;
foreach(var item in mailBody)
{
timesheetData = new TimesheetDetailModel();
timesheetData.Task_Id = matrix.Task_Id;
timesheetData.Hours = matrix.Hours;
//timesheetData.Date = matrix.Date.Date;
timesheetData.Date = matrix.Date.AddDays(1);
timesheetData.EmpId = Convert.ToInt32(Session["EmpId"].ToString());
timesheetData.Notes = matrix.Notes;
strMsg = strMsg+ " <tr><td> " + timesheetData.Date.ToString("dd/MM/yyyy") + "</td><td>" + timesheetData.Hours + "</td><td>" + task + "</td><td>" + timesheetData.Notes + "</td></tr>";
n++;
}
strMsg = strMsg + "</table>";