1. POP3协议监听110端口
2. 命令为大小写不敏感
3. 所有的命令以CRLF(回车)作为结束
4. 命令关键字以及参数由ASCII字符组成
5. 关键字与参数通过空格分隔
6. 关键字为3-4字符长度
7. 参数可达到40字符长度
8. POP3返回信息由一个“状态符”和一个可能带有附加信息的关键字组成。所有的返回都以回车(CRLF)做终结。响应信息包括CRLF可以达到512字符的长度。目前有两个状态符”+OK”,”-ERR”,响应信息中的状态符必须大写。
9. 如果响应信息由多行组成,那么除最后一行以CRLF结尾,最后一行以八进制字符046(.) 以及一个CRLF做结尾。如果行以046(.)开头,但其后并不是CRLF,那么046(.)被忽略;如果行以046(.)以及CRLF开头,响应结束,其后内容被忽略。
10. 一个POP3会话,在它的生命周期里,是通过一系列的状态转换来标识的。一个会话被建立,服务器返回问候信息时,会话进入“AUTHORIZATION”。在这个状态里,客户端需要发送身份信息到服务端验证身份。一旦身份信息被确认后,服务端开始向客户端发送邮件信息并进入“TRANSACTION”状态;当客户端提供“QUIT”指令,会话进入“UPDATE”状态,服务器释放资源。
11. 无论是因为服务端无法执行客户端命令,还是因为服务端状态出错,服务端都会返回“-ERR”,客户端目前没有一个有效的方法去检测-ERR的真正含义
12. POP3会为每次会话提供一个活动时钟,建议把这个时间设置为至少10分钟。每次接收客户端命令,服务端都会重置时钟,如果时钟超时,服务端不会进入UPDATE状态而直接关闭会话。
13. POP3连接被建立后,服务端会返回一行欢迎信息以及一个正向状态字。如:
S: +OK POP3 server ready
此时服务端进入 AUTHORIZATION状态。服务端此时需要验证客户端的身份信息。客户
端需要使用USER,PASS命令提供身份信息。
14. 身份信息被建立后,客户端被允许访问相应的邮件帐户,服务端此时会为该邮件帐户啊施加一个排他锁,以防止会话期间邮件信息被修改或者删除。如果排他锁被建立成功,服务端会返回正向状态字,会话也由此进入”TRANSACTION”状态。如果此时无法为邮件帐户建立排他锁(已被锁或者其他问题),服务端会返回负向状态位。在返回了负向状态位之后,会话将被关闭。如果没有关闭,客户端可以提供一个新的身份信息或者客户端主动关闭连接(QUIT)。
15. 在服务端为客户端建立好相应的帐户连接后,会为每条信息分配信息编号,并计算信息的长度,信息便和以及信息长度会以10进制显示。
16. 在通过服务端认证,并且服务端成功为邮件帐户加锁后,服务端进入TRANSACTION状态。TRANSACTION阶段,客户端可以通过以下命令同服务端进行交互:
a) STAT 返回当前服务端状态,信息条数,信息大小
C: STAT
S: +OK 2 320
b) LIST [msg num] 信息列表(包括编号以及尺寸)
C: LIST
S: +OK 2 messages (320 octets)
1 20
2 40
3 ….
C: LIST 1
S: +OK 1 20
c) RETR msgnum 根据编号,返回信息
C: RETR 1
S: +OK 120 octets
S: <the POP3 server sends the entire message here>
d) DELE msgnum 根据编号,删除信息,信息不会立即被删除,在关闭连接后被删除
C: DELE 1
S: +OK message 1 deleted
e) RSET 如果邮箱里有任意信息被DELE了,恢复该信息
C: RSET
S: +OK maildrop has 2 messages (320 octets)
17. UPDATE 状态下的命令
a) QUIT
18. 以上命令为POP3服务器必须实现的,以下命令为可选实现的
a) TOP msgnun linenum 根据信息编号,返回相应信息的前linenum行
b) UIDL [msgnum] 根据信息编号,返回一个该信息的唯一id
c) USER name
d) PASS string
e) APOP