前言
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