前言
IMAP全稱是Internet Mail Access Protocol,即交互式郵件存取協(xié)議,它是跟POP3類似郵件訪問標(biāo)準(zhǔn)協(xié)議之一。不同的是,開啟了IMAP后,您在電子郵件客戶端收取的郵件仍然保留在服務(wù)器上,同時在客戶端上的操作都會反饋到服務(wù)器上,如:刪除郵件,標(biāo)記已讀等,服務(wù)器上的郵件也會做相應(yīng)的動作。所以無論從瀏覽器登錄郵箱或者客戶端軟件登錄郵箱,看到的郵件以及狀態(tài)都是一致的。
最近我要做一個爬蟲。這個爬蟲需要如下幾個步驟:
1 填寫注冊內(nèi)容(需要郵箱注冊)
2 過拖拽驗(yàn)證碼(geetest)
3 注冊成功會給郵箱發(fā)一封確認(rèn)郵箱
4 點(diǎn)擊確認(rèn)郵箱中的鏈接 完成注冊
我這里就采用163郵箱注冊。
郵箱協(xié)議有 pop3 和 imap 和 smtp
我試了pop3 不能夠篩選郵件 例如篩選未讀 和 發(fā)件人這2個條件 所以放棄用pop3
imap協(xié)議是支持的。
我就找了一個開源的第三方lib:S22.Imap
用法很簡單:
public void Test163() { var imapServer = "imap.163.com"; var port = 993; using (ImapClient client = new ImapClient(imapServer, port, "xxxx@163.com", "pwd", AuthMethod.Login, true)) { // Returns a collection of identifiers of all mails matching the specified search criteria. IEnumerable<uint> uids = client.Search(SearchCondition.Unseen()); // Download mail messages from the default mailbox. IEnumerable<MailMessage> messages = client.GetMessages(uids,FetchOptions.HtmlOnly); Console.WriteLine("We are connected!"); } }
發(fā)現(xiàn) 在login的時候 報錯了:
提示“NO Select Unsafe Login. Please contact kefu@188.com for help”。
163郵箱也會收到一個告警郵件
經(jīng)過查證 發(fā)現(xiàn)得需要在發(fā)送 login 命令之前 得先發(fā)送 id 命令
至于為什么要這么做 我的理解是得先偽裝成普通的客戶端吧(有理解錯誤請指出謝謝)
我fork了一份SS2.imap的代碼 打算兼容163的這個特殊情況改掉源碼
然后走Login方法就不會報錯了
Github地址:https://github.com/yuzd/S22.Imap
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網(wǎng)的支持。
新聞熱點(diǎn)
疑難解答
圖片精選