usando c # .net bibliotecas para verificar se há mensagens IMAP dos servidores do Gmail [fechado]

StackOverflow https://stackoverflow.com/questions/545724

  •  23-08-2019
  •  | 
  •  

Pergunta

Alguém tem qualquer código de exemplo no que faz uso do framework .Net que se conecta a servidores googlemail via IMAP SSL para verificar se há novos e-mails?

Outras dicas

Como o autor do projeto acima, posso dizer que sim ele faz SSL apoio.

Atualmente, estou trabalhando em uma nova versão da biblioteca que será totalmente assíncrona para aumentar a velocidade com que pode interagir com servidores IMAP.

Esse código, embora não completo, pode ser baixado, juntamente com a biblioteca síncrona original (que também suporta SSL), a partir do site plex código relacionado acima.

Eu recomendo olhar MailKit como é provavelmente a biblioteca de correio robusto mais lá fora, e é Open Source (MIT) .

Uma das coisas impressionantes sobre MailKit é que todas as APIs de rede são canceláveis ??(algo que eu não vi disponível em qualquer outra biblioteca IMAP).

Também é a única biblioteca que eu conheço que suporta segmentação de mensagens.

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);
                }
            }
        }
    }
}

Cross postado do outro pergunta semelhante. Veja o que acontece quando eles ficam tão semelhantes?

Eu tenho procurado para uma solução IMAP por um tempo agora, e depois de tentar muito poucos, eu vou com AE.Net.Mail .

Não existe documentação, que considero uma desvantagem, mas eu era capaz de chicote isso por olhar para o código-fonte (yay para o código aberto!) E usando Intellisense. O código abaixo liga especificamente ao servidor IMAP do Gmail:

// 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();

Eu não sou afiliado com esta biblioteca ou qualquer coisa, mas eu achei muito rápido e estável.

Lumisoft.net tem tanto o cliente IMAP e código do servidor que você pode usar.

Eu usei-o para baixar e-mail do Gmail. O modelo de objeto não é a melhor, mas é viável, e parece ser bastante flexível e estável.

Aqui está o resultado parcial do meu pico para usá-lo. Ele busca os primeiros 10 cabeçalhos com envelopes, e, em seguida, obtém a mensagem completa:

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);

    }
}

Não há suporte .NET framework para IMAP. Você vai precisar usar alguns 3rd componente partido.

Tente Mail.dll email componente , é muito acessível e fácil para uso, ele também suporta 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);
}

Por favor note que este é um produto comercial que criei.

Você pode baixá-lo aqui:. https://www.limilabs.com/mail

MailSystem.NET contém toda a sua necessidade de IMAP4. É fonte livre e aberta.

(estou envolvido no projeto)

a fonte para a versão SSL disso é aqui: http://atmospherian.wordpress.com/downloads /

Outra alternativa: HigLabo

https://higlabo.codeplex.com/documentation

Boa discussão: 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 - funciona muito bem, bastante fácil. Compila com .NET 4.0.

Aqui estão os links necessários para sua lib e exemplos. Downloads principal:

http://www.lumisoft.ee/lsWWW/Download/Downloads/

Exemplos de código:

estão localizados aqui: ... lsWWW / Download / Download / Exemplos /

NET:

estão localizados aqui: ... lsWWW / Download / Download / Net /

Estou colocando uma amostra SIMPLES usando sua lib no CodePlex (IMAPClientLumiSoft.codeplex.com). Você deve obter suas bibliotecas diretamente de seu site. Eu não estou incluindo-los porque eu não manter o seu código nem tenho quaisquer direitos sobre o código. Ir para os links acima e baixá-lo diretamente. I definir propriedades do projeto Lumisoft no meu VS2010 para construir tudo isso em .NET 4.0 que fez sem erros. Suas amostras são bastante complexas e talvez até excessivamente apertado codificação quando apenas um exemplo. Embora eu espere que estes são destinados a desenvolvedores de nível avançado em geral.

O projeto trabalhou com pequenos ajustes. Os ajustes: Sua IMAP Cliente Winform exemplo é definido nas propriedades do projeto como "Release" que impede VS de quebrar em pontos de depuração. Você deve usar a solução "Configuration Manager" para definir o projeto para "Ativo (Debug)" para pontos de interrupção para o trabalho. Seus exemplos usar métodos anônimos para manipuladores de eventos que é grande apertado de codificação ... não é real boa como ferramenta de ensino. Meu projeto usa o "chamado" método de evento manipuladores para que você possa definir pontos de interrupção dentro dos manipuladores. No entanto deles é uma excelente maneira de lidar com código embutido. Eles poderiam ter usado os métodos mais recentes Lambda disponíveis desde .NET 3.0, mas não o fez e eu não tentou convertê-los.

A partir de suas amostras I simplificou o cliente IMAP para mínimo.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top