System.Net.Mail SmtpClientクラス非同期で電子メールを送信
5513 ワード
電子メールを送信し、SMTPサーバへの電子メールの送信待ち中に他の操作をブロックするには、同期Sendメソッドを使用します.プログラムのプライマリ・スレッドが電子メールの送信中に実行されるようにするには、非同期SendAsyncメソッドを使用します.SendAsync操作が完了すると、SendCompletedイベントが発生します.このイベントを受信するには、SendCompleted EventHandler依頼をSendCompletedに追加する必要があります.SendCompletedEventHandler依頼は、SendCompletedイベント通知を処理するコールバックメソッドを参照する必要があります.非同期Eメール転送をキャンセルするには、SendAsyncCancelメソッドを使用します.
Eメール送信中にSendAsyncまたはSendを再度呼び出すと、InvalidOperationExceptionが受信されます.
次のコード例では、電子メールを非同期で送信する方法を示します.
C#
mvs 2008ドキュメントから
Eメール送信中にSendAsyncまたはSendを再度呼び出すと、InvalidOperationExceptionが受信されます.
次のコード例では、電子メールを非同期で送信する方法を示します.
C#
using System;
using System.Net;
using System.Net.Mail;
using System.Net.Mime;
using System.Threading;
using System.ComponentModel;
namespace Examples.SmptExamples.Async
{
public class SimpleAsynchronousExample
{
static bool mailSent = false;
private static void SendCompletedCallback(object sender, AsyncCompletedEventArgs e)
{
// Get the unique identifier for this asynchronous operation.
String token = (string) e.UserState;
if (e.Cancelled)
{
Console.WriteLine("[{0}] Send canceled.", token);
}
if (e.Error != null)
{
Console.WriteLine("[{0}] {1}", token, e.Error.ToString());
} else
{
Console.WriteLine("Message sent.");
}
mailSent = true;
}
public static void Main(string[] args)
{
// Command line argument must the the SMTP host.
SmtpClient client = new SmtpClient(args[0]);
// Specify the e-mail sender.
// Create a mailing address that includes a UTF8 character
// in the display name.
MailAddress from = new MailAddress("[email protected]",
"Jane " + (char)0xD8+ " Clayton",
System.Text.Encoding.UTF8);
// Set destinations for the e-mail message.
MailAddress to = new MailAddress("[email protected]");
// Specify the message content.
MailMessage message = new MailMessage(from, to);
message.Body = "This is a test e-mail message sent by an application. ";
// Include some non-ASCII characters in body and subject.
string someArrows = new string(new char[] {'/u2190', '/u2191', '/u2192', '/u2193'});
message.Body += Environment.NewLine + someArrows;
message.BodyEncoding = System.Text.Encoding.UTF8;
message.Subject = "test message 1" + someArrows;
message.SubjectEncoding = System.Text.Encoding.UTF8;
// Set the method that is called back when the send operation ends.
client.SendCompleted += new
SendCompletedEventHandler(SendCompletedCallback);
// The userState can be any object that allows your callback
// method to identify this send operation.
// For this example, the userToken is a string constant.
string userState = "test message1";
client.SendAsync(message, userState);
Console.WriteLine("Sending message... press c to cancel mail. Press any other key to exit.");
string answer = Console.ReadLine();
// If the user canceled the send, and mail hasn't been sent yet,
// then cancel the pending operation.
if (answer.StartsWith("c") && mailSent == false)
{
client.SendAsyncCancel();
}
// Clean up.
message.Dispose();
Console.WriteLine("Goodbye.");
}
}
}
mvs 2008ドキュメントから