IMAP SSLを介してgooglemailサーバーに接続して新しいメールをチェックする.Netフレームワークを利用するサンプルコードを持っている人はいますか?
10 に答える
おそらく最も堅牢なメール ライブラリであり、オープン ソース (MIT) であるため、 MailKitを検討することをお勧めします。
MailKit の素晴らしい点の 1 つは、すべてのネットワーク API がキャンセル可能であることです (これは、他の IMAP ライブラリでは利用できない機能です)。
メッセージのスレッド化をサポートする、私が知っている唯一のライブラリでもあります。
using System;
using System.Net;
using System.Threading;
using MailKit.Net.Imap;
using MailKit.Search;
using MailKit;
using MimeKit;
namespace TestClient {
class Program
{
public static void Main (string[] args)
{
using (var client = new ImapClient ()) {
using (var cancel = new CancellationTokenSource ()) {
client.Connect ("imap.gmail.com", 993, true, cancel.Token);
// If you want to disable an authentication mechanism,
// you can do so by removing the mechanism like this:
client.AuthenticationMechanisms.Remove ("XOAUTH");
client.Authenticate ("joey", "password", cancel.Token);
// The Inbox folder is always available...
var inbox = client.Inbox;
inbox.Open (FolderAccess.ReadOnly, cancel.Token);
Console.WriteLine ("Total messages: {0}", inbox.Count);
Console.WriteLine ("Recent messages: {0}", inbox.Recent);
// download each message based on the message index
for (int i = 0; i < inbox.Count; i++) {
var message = inbox.GetMessage (i, cancel.Token);
Console.WriteLine ("Subject: {0}", message.Subject);
}
// let's try searching for some messages...
var query = SearchQuery.DeliveredAfter (DateTime.Parse ("2013-01-12"))
.And (SearchQuery.SubjectContains ("MailKit"))
.And (SearchQuery.Seen);
foreach (var uid in inbox.Search (query, cancel.Token)) {
var message = inbox.GetMessage (uid, cancel.Token);
Console.WriteLine ("[match] {0}: {1}", uid, message.Subject);
}
client.Disconnect (true, cancel.Token);
}
}
}
}
}
上記のプロジェクトの作成者として、はい、SSL をサポートしていると言えます。
私は現在、IMAP サーバーとのやり取りの速度を上げるために完全に非同期になるライブラリの新しいバージョンに取り組んでいます。
このコードは完全ではありませんが、元の同期ライブラリ (SSL もサポート) とともに、上記のリンク先のコード プレックス サイトからダウンロードできます。
他の同様の質問から投稿されたクロス。彼らがとても似ているとどうなるか見てみましょう。
私はしばらく IMAP ソリューションを探していましたが、かなりの数を試した後、AE.Net.Mailを使用しています。
ドキュメントはありませんが、これはマイナス面だと思いますが、ソース コードを調べて (オープン ソースに賛成です!)、Intellisense を使用することで、これを改善することができました。以下のコードは、特に Gmail の IMAP サーバーに接続します。
// Connect to the IMAP server. The 'true' parameter specifies to use SSL
// which is important (for Gmail at least)
ImapClient ic = new ImapClient("imap.gmail.com", "name@gmail.com", "pass",
ImapClient.AuthMethods.Login, 993, true);
// Select a mailbox. Case-insensitive
ic.SelectMailbox("INBOX");
Console.WriteLine(ic.GetMessageCount());
// Get the first *11* messages. 0 is the first message;
// and it also includes the 10th message, which is really the eleventh ;)
// MailMessage represents, well, a message in your mailbox
MailMessage[] mm = ic.GetMessages(0, 10);
foreach (MailMessage m in mm)
{
Console.WriteLine(m.Subject);
}
// Probably wiser to use a using statement
ic.Dispose();
私はこのライブラリなどと提携していませんが、非常に高速で安定しています。
Lumisoft.netには、使用できる IMAP クライアント コードとサーバー コードの両方があります。
Gmailからメールをダウンロードするために使用しました。オブジェクト モデルは最適ではありませんが、実行可能であり、かなり柔軟で安定しているようです。
これは、スパイクを使用した結果の一部です。エンベロープを含む最初の 10 個のヘッダーをフェッチしてから、完全なメッセージをフェッチします。
using (var client = new IMAP_Client())
{
client.Connect(_hostname, _port, _useSsl);
client.Authenticate(_username, _password);
client.SelectFolder("INBOX");
var sequence = new IMAP_SequenceSet();
sequence.Parse("0:10");
var fetchItems = client.FetchMessages(sequence, IMAP_FetchItem_Flags.Envelope | IMAP_FetchItlags.UID,
false, true);
foreach (var fetchItem in fetchItems)
{
Console.Out.WriteLine("message.UID = {0}", fetchItem.UID);
Console.Out.WriteLine("message.Envelope.From = {0}", fetchItem.Envelope.From);
Console.Out.WriteLine("message.Envelope.To = {0}", fetchItem.Envelope.To);
Console.Out.WriteLine("message.Envelope.Subject = {0}", fetchItem.Envelope.Subject);
Console.Out.WriteLine("message.Envelope.MessageID = {0}", fetchItem.Envelope.MessageID);
}
Console.Out.WriteLine("Fetching bodies");
foreach (var fetchItem in client.FetchMessages(sequence, IMAP_FetchItem_Flags.All, false, true)
{
var email = LumiSoft.Net.Mail.Mail_Message.ParseFromByte(fetchItem.MessageData);
Console.Out.WriteLine("email.BodyText = {0}", email.BodyText);
}
}
IMAP に対する .NET フレームワークのサポートはありません。サードパーティのコンポーネントを使用する必要があります。
Mail.dll 電子メール コンポーネントを試してみてください。非常に手頃な価格で使いやすく、SSLもサポートしています。
using(Imap imap = new Imap())
{
imap.ConnectSSL("imap.company.com");
imap.Login("user", "password");
imap.SelectInbox();
List<long> uids = imap.Search(Flag.Unseen);
foreach (long uid in uids)
{
string eml = imap.GetMessageByUID(uid);
IMail message = new MailBuilder()
.CreateFromEml(eml);
Console.WriteLine(message.Subject);
Console.WriteLine(message.Text);
}
imap.Close(true);
}
これは私が作成した商用製品であることに注意してください。
https://www.limilabs.com/mailからダウンロードできます。
MailSystem.NETには、IMAP4 に必要なものがすべて含まれています。無料でオープンソースです。
(私はそのプロジェクトに参加しています)
これの SSL バージョンのソースはこちら: http://atmospherian.wordpress.com/downloads/
別の選択肢:HigLabo
https://higlabo.codeplex.com/documentation
良い議論: https://higlabo.codeplex.com/discussions/479250
//====Imap sample================================//
//You can set default value by Default property
ImapClient.Default.UserName = "your server name";
ImapClient cl = new ImapClient("your server name");
cl.UserName = "your name";
cl.Password = "pass";
cl.Ssl = false;
if (cl.Authenticate() == true)
{
Int32 MailIndex = 1;
//Get all folder
List<ImapFolder> l = cl.GetAllFolders();
ImapFolder rFolder = cl.SelectFolder("INBOX");
MailMessage mg = cl.GetMessage(MailIndex);
}
//Delete selected mail from mailbox
ImapClient pop = new ImapClient("server name", 110, "user name", "pass");
pop.AuthenticateMode = Pop3AuthenticateMode.Pop;
Int64[] DeleteIndexList = new.....//It depend on your needs
cl.DeleteEMail(DeleteIndexList);
//Get unread message list from GMail
using (ImapClient cl = new ImapClient("imap.gmail.com"))
{
cl.Port = 993;
cl.Ssl = true;
cl.UserName = "xxxxx";
cl.Password = "yyyyy";
var bl = cl.Authenticate();
if (bl == true)
{
//Select folder
ImapFolder folder = cl.SelectFolder("[Gmail]/All Mail");
//Search Unread
SearchResult list = cl.ExecuteSearch("UNSEEN UNDELETED");
//Get all unread mail
for (int i = 0; i < list.MailIndexList.Count; i++)
{
mg = cl.GetMessage(list.MailIndexList[i]);
}
}
//Change mail read state as read
cl.ExecuteStore(1, StoreItem.FlagsReplace, "UNSEEN")
}
//Create draft mail to mailbox
using (ImapClient cl = new ImapClient("imap.gmail.com"))
{
cl.Port = 993;
cl.Ssl = true;
cl.UserName = "xxxxx";
cl.Password = "yyyyy";
var bl = cl.Authenticate();
if (bl == true)
{
var smg = new SmtpMessage("from mail address", "to mail addres list"
, "cc mail address list", "This is a test mail.", "Hi.It is my draft mail");
cl.ExecuteAppend("GMail/Drafts", smg.GetDataText(), "\\Draft", DateTimeOffset.Now);
}
}
//Idle
using (var cl = new ImapClient("imap.gmail.com", 993, "user name", "pass"))
{
cl.Ssl = true;
cl.ReceiveTimeout = 10 * 60 * 1000;//10 minute
if (cl.Authenticate() == true)
{
var l = cl.GetAllFolders();
ImapFolder r = cl.SelectFolder("INBOX");
//You must dispose ImapIdleCommand object
using (var cm = cl.CreateImapIdleCommand()) Caution! Ensure dispose command object
{
//This handler is invoked when you receive a mesage from server
cm.MessageReceived += (Object o, ImapIdleCommandMessageReceivedEventArgs e) =>
{
foreach (var mg in e.MessageList)
{
String text = String.Format("Type is {0} Number is {1}", mg.MessageType, mg.Number);
Console.WriteLine(text);
}
};
cl.ExecuteIdle(cm);
while (true)
{
var line = Console.ReadLine();
if (line == "done")
{
cl.ExecuteDone(cm);
break;
}
}
}
}
}
LumiSoft.ee - 非常に簡単に機能します。.NET 4.0 でコンパイルします。
ライブラリと例への必要なリンクは次のとおりです。ダウンロード メイン:
http://www.lumisoft.ee/lsWWW/Download/Downloads/
コード例:
...lsWWW/Download/Downloads/Examples/ にあります。
。ネット:
...lsWWW/Download/Downloads/Net/ にあります。
私は、codeplex (IMAPClientLumiSoft.codeplex.com) で lib を使用して SIMPLE サンプルを作成しています。サイトからライブラリを直接取得する必要があります。私はそれらのコードを保守しておらず、コードに対する権利も持っていないため、それらを含めません。上記のリンクにアクセスして、直接ダウンロードしてください。VS2010 で LumiSoft プロジェクトのプロパティを設定して、すべてを .NET 4.0 でビルドしましたが、エラーは発生しませんでした。彼らのサンプルはかなり複雑で、単なる例としては過度にタイトなコーディングでさえあります. これらは一般的に上級レベルの開発者を対象としていると思いますが。
彼らのプロジェクトは、わずかな調整で機能しました。微調整: IMAP クライアントの Winform の例は、プロジェクトのプロパティで「リリース」として設定され、VS がデバッグ ポイントで中断するのを防ぎます。ブレークポイントを機能させるには、ソリューション「構成マネージャー」を使用してプロジェクトを「アクティブ (デバッグ)」に設定する必要があります。彼らの例では、非常にタイトなコーディングであるイベント ハンドラーに匿名メソッドを使用しています... 教育ツールとしてはあまり良くありません。私のプロジェクトでは、「名前付き」イベント メソッド ハンドラを使用しているため、ハンドラ内にブレークポイントを設定できます。ただし、インライン コードを処理する優れた方法です。彼らは .NET 3.0 以降に利用可能な新しい Lambda メソッドを使用していた可能性がありますが、使用していませんでしたし、私もそれらを変換しようとしませんでした。
彼らのサンプルから、私は IMAP クライアントを最小限に単純化しました。