如何使用pop3 c#从Yahoo邮件中读取最新的电子邮件

时间:2016-10-24 13:19:36

标签: c# pop3 email-client yahoo-mail openpop

我想阅读我的雅虎邮箱帐户中的电子邮件。我正在使用“OpenPop.Pop3”来阅读我的雅虎邮箱帐户中的电子邮件,我使用的是以下代码: -

using OpenPop.Pop3;    

public DataTable ReadEmailsFromId()
{
    DataTable table = new DataTable();
    try
    {
        using (Pop3Client client = new Pop3Client())
        {
            client.Connect("pop.mail.yahoo.com", 995, true); //For SSL                
            client.Authenticate("Username", "Password", AuthenticationMethod.UsernameAndPassword);

            int messageCount = client.GetMessageCount();
            for (int i = messageCount; i > 0; i--)
            {
                table.Rows.Add(client.GetMessage(i).Headers.Subject, client.GetMessage(i).Headers.DateSent);
                string msdId = client.GetMessage(i).Headers.MessageId;
                OpenPop.Mime.Message msg = client.GetMessage(i);
                OpenPop.Mime.MessagePart plainTextPart = msg.FindFirstPlainTextVersion();
                string message = plainTextPart.GetBodyAsText();                           
            }
        }
    }
return table;
}

相同的代码能够访问其他邮件电子邮件,如gmail,outlook,但在使用雅虎邮件电子邮件时,我能够获得主题,日期,但是当来到消息部分时:

OpenPop.Mime.Message msg = client.GetMessage(i);
OpenPop.Mime.MessagePart plainTextPart = msg.FindFirstPlainTextVersion();

它给出错误“用于检索响应的流已关闭”。

这是“StackTrace”:

at OpenPop.Pop3.Pop3Client.IsOkResponse(String response)
at OpenPop.Pop3.Pop3Client.SendCommand(String command)
at OpenPop.Pop3.Pop3Client.Disconnect()
at OpenPop.Pop3.Pop3Client.Dispose(Boolean disposing)
at OpenPop.Pop3.Disposable.Dispose()

如果我遗漏了某些东西或做错了什么,请告诉我。 此外,我还使用POP在任何地方访问雅虎邮件电子邮件。

1 个答案:

答案 0 :(得分:0)

首先,根据您的代码段,您将下载每封邮件4次。那将是非常缓慢的。

至于你收到错误的原因,我不知道。我使用MailKit收到错误:

using MimeKit;
using MailKit;
using MailKit.Net.Pop3;    

public DataTable ReadEmailsFromId()
{
    DataTable table = new DataTable();
    try
    {
        using (Pop3Client client = new Pop3Client())
        {
            client.Connect("pop.mail.yahoo.com", 995, true); //For SSL                
            client.Authenticate("Username", "Password");

            for (int i = client.Count - 1; i >= 0; i--)
            {
                var msg = client.GetMessage (i);

                table.Rows.Add(msg.Subject, msg.Date);
                string msdId = msg.MessageId;
                string message = msg.TextBody;
            }
        }
    }
return table;
}