[英]Sending email within .NET Task not working in console application
我下面有以下代碼。 它在控制台應用程序的末尾運行。 在任務中完成任務后,我沒有收到發送出去的電子郵件,但是當我注釋掉任務工廠方法時,它行得通嗎? 代碼兩次都帶有斷點,但是異步電子郵件流從未發送過電子郵件。 有什么原因嗎?
Task.Factory.StartNew(() =>
{
var smtp = new SmtpClient();
try
{
var toEmails = mailMessage.To.ToList();
var bccEmails = mailMessage.Bcc.ToList();
foreach (var email in toEmails)
{
mailMessage.To.Clear();
mailMessage.To.Add(email);
mailMessage.Bcc.Clear();
smtp.Send(mailMessage);
}
}
catch (Exception ex)
{
Logger.Error(ex);
}
});
正如您所說的“這在控制台應用程序的末尾運行” ,我假設您的Main
方法在Task.Factory.Startnew
有機會在后台線程中完成運行之前終止。
您應該:
明確等待任務使用Task.Wait
完成,同時阻止執行Main
方法,這Task.Wait
錯過了使用ThreadPool
線程的意義(我不會這樣做):
Task.Factory.StartNew(() => { var smtp = new SmtpClient(); try { var toEmails = mailMessage.To.ToList(); var bccEmails = mailMessage.Bcc.ToList(); foreach (var email in toEmails) { mailMessage.To.Clear(); mailMessage.To.Add(email); mailMessage.Bcc.Clear(); smtp.Send(mailMessage); } } catch (Exception ex) { Logger.Error(ex); } }).Wait();
編輯
我不得不補充一點,出於以下幾個原因,我建議您不要使用公共庫中的代碼:
ThreadPool
線程來執行基於IO的工作 Wait
,而您不需要它。 如果您想使用一個真正的異步api(不需要使用線程來執行IO綁定工作),則可以使用SmtpClient.SendMailAsync
並簡單地await
它:
var smtp = new SmtpClient();
try
{
var toEmails = mailMessage.To.ToList();
var bccEmails = mailMessage.Bcc.ToList();
var taskMails = toEmails.Select(email =>
{
var message = new MailMessage
{
To = email
};
smtp.SendMailAsync(message);
};
await Task.WhenAll(taskEmails);
}
catch (Exception ex)
{
Logger.Error(ex);
}
我選擇了Task的返回類型,這使我可以選擇是否等待。
var task = _emailService.Send(new List<string> { @event.ContactEmail }, subject, body,
new List<Attachment>
{
new Attachment(new MemoryStream(bytes), report.FileName, "application/pdf")
});
if (task != null)
{
task.Wait();
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.