前言
imap全稱是internet mail access protocol,即交互式郵件存取協議,它是跟pop3類似郵件訪問標準協議之一。不同的是,開啟了imap后,您在電子郵件客戶端收取的郵件仍然保留在服務器上,同時在客戶端上的操作都會反饋到服務器上,如:刪除郵件,標記已讀等,服務器上的郵件也會做相應的動作。所以無論從瀏覽器登錄郵箱或者客戶端軟件登錄郵箱,看到的郵件以及狀態都是一致的。
最近我要做一個爬蟲。這個爬蟲需要如下幾個步驟:
1 填寫注冊內容(需要郵箱注冊)
2 過拖拽驗證碼(geetest)
3 注冊成功會給郵箱發一封確認郵箱
4 點擊確認郵箱中的鏈接 完成注冊
我這里就采用163郵箱注冊。
郵箱協議有 pop3 和 imap 和 smtp
我試了pop3 不能夠篩選郵件 例如篩選未讀 和 發件人這2個條件 所以放棄用pop3
imap協議是支持的。
我就找了一個開源的第三方lib:s22.imap
用法很簡單:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
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!" ); } } |
發現 在login的時候 報錯了:
提示“no select unsafe login. please contact kefu@188.com for help”。
163郵箱也會收到一個告警郵件
經過查證 發現得需要在發送 login 命令之前 得先發送 id 命令
至于為什么要這么做 我的理解是得先偽裝成普通的客戶端吧(有理解錯誤請指出謝謝)
我fork了一份ss2.imap的代碼 打算兼容163的這個特殊情況改掉源碼
然后走login方法就不會報錯了
github地址:https://github.com/yuzd/s22.imap
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
原文鏈接:http://www.cnblogs.com/yudongdong/p/8465551.html