详解电子邮件的POP3协议及最小化实现

简介: 详解电子邮件的POP3协议及最小化实现

详细解释电子邮件中POP3协议及最小化实现


1.     什么是POP3


POP3的英文全称Post OfficeProtocol Version 3,POP3协议本质上是一种消息传递协议


主要用来在支持POP3客户端和POP3邮件服务器端通信,基于TCP协议之上的应用层协议


POP3协议主要用来读取邮件服务器上的电子邮件。发送邮件时候支持的协议为SMTP.


此外还有一种同时支持收发邮件协议IMAP.



直白的说,当你的邮件客户端检查你是否有新邮件以及读新邮件是,很可能协议为POP3


当你写完一封Email,发送给指定收件人时候,很可能是通过SMTP协议,当然还可以是IMAP。

协议

支持发送邮件

支持接受邮件

POP3

No

Yes

SMTP/ESMTP

Yes

No

IMAP

Yes

Yes

2.     基本操作

服务器端启动POP3服务在端口110, Google Mail是SSL加密的,在端口995。当客户端连

接成功之后,服务器端首先会发送一条问候信息(Greet).然后服务器端与客户端开始会话操作

知道客户端断开连接或者退出会话。

基本的会话类型分为两个阶段 – 第一阶段为授权状态;第二个阶段为传输状态



授权状态(AUTHORIZATION State)支持三个命令为【USER, PASS, QUIT】:


-         USER <name> -  <name>参数是必须的,指要求的UserID,通常为Email帐号

-         PASS <password><password>参数是必须的,指要求的Email帐号密码


-         QUIT 不需要任何参数,表示退出,结束与POP3服务器的会话



传输状态(TRANSACTION State)支持命令为【STAT, LIST, RETR, DELE,


NOOP,LAST, RSET】


-         STAT 不需要任何参数,列出当前邮箱中所有的邮件总数及大小


-         LIST [message id] 参数可选,列出当前邮箱每封邮件及其大小


-         RETR <Message id> 参数是必须的,读出指定message id的邮件内容


-         DELE <Message id> 参数是必须的,删除指定message id 的邮件


-         NOOP 不需要任何参数,POP3服务器只是发一条问候消息作为响应


-         LAST 不需要任何参数,返回Client最后访问过的消息ID,如何没有任何email被客户端


读过,返回最大的Message Id 1, 如何邮箱里面没有任何email,返回 0


-         RSET 不需要任何参数, 任何被标记为删除的邮件将被恢复



最后,当QUIT命令发布以后客户端退出,服务器端则进入更新状态(UPDATE State)。


一个是Google MailPOP3 会话的例子如下:

0_1332321692B1vj.jpg

3.     一个最小化命令集的Java实现

package com.gloomyfish.sslsocket.study;
 
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
 
import javax.net.ssl.SSLSocket;
import javax.net.ssl.SSLSocketFactory;
 
public class POP3Client {
  private static DataOutputStream writer;
  public static void main(String[] args) throws Exception
  {
    int delay = 6000;// give enough delay to get response message from POP server
    SSLSocket sock = (SSLSocket)((SSLSocketFactory)SSLSocketFactory.getDefault()).createSocket("pop.gmail.com", 995);
    final BufferedReader br = new BufferedReader(new InputStreamReader(sock.getInputStream()));
    (new Thread(new Runnable()
    {
      public void run()
      {
        try
        {
          String line;
          while((line = br.readLine()) != null)
            System.out.println(" S: "+line);
        }
        catch (IOException e)
        {
          e.printStackTrace();
        }
      }
    })).start();
    writer = new DataOutputStream(sock.getOutputStream());
    
    // start to AUTHORIZATION State
    send("USER YOUREMAILID\r\n");
    Thread.sleep(delay);
    send("PASS YOURPASSWORD\r\n");
    Thread.sleep(delay);
    // end AUTHORIZATION State
    
    // start <<The TRANSACTION State>>
    send("STAT\r\n"); // check new arrived mail
    Thread.sleep(delay);
    
    // List Mail
    send("LIST 1\r\n"); // check new arrived mail
    Thread.sleep(delay);
    
    // Fetch the message here [RETR <SP> msg CRLF]
    send("RETR 1\r\n"); // check new arrived mail
    Thread.sleep(delay);
    
    // DELET
    send("DELE 1\r\n"); // check new arrived mail
    Thread.sleep(delay);
    
    // UNMARKER THE DELETED EMAIL
    send("RSET\r\n"); // check new arrived mail
    Thread.sleep(delay);
    // end The TRANSACTION State
    
    // issue the [quit] command from client.
    send("QUIT\r\n");
    Thread.sleep(delay);
  }
  
  private static void send(String s) throws Exception
  {
    writer.writeBytes(s);
    System.out.println(" C: "+s);
  }
 
}

相关文章
|
6月前
|
人工智能 搜索推荐 数据可视化
Manus:或将成为AI Agent领域的标杆
随着人工智能技术的飞速发展,AI Agent(智能体)作为人工智能领域的重要分支,正逐渐从概念走向现实,并在各行各业展现出巨大的应用潜力。在众多AI Agent产品中,Manus以其独特的技术优势和市场表现,有望成为该领域的标杆。作为资深AI工程师,本文将深入探讨Manus的背景知识、主要业务场景、底层原理、功能的优缺点,并尝试使用Java搭建一个属于自己的Manus助手,以期为AI Agent技术的发展和应用提供参考。
12707 19
|
资源调度 JavaScript Windows
yarn install命令报错解决办法-warning package-lock.json found.
yarn install命令报错解决办法-warning package-lock.json found.
598 0
|
监控 Kubernetes Cloud Native
浅谈基于 OpenStack 和 k8s 建设云原生研发基础设施
建设公司云原生研发基础设施,为研发部门提供安全、可靠、高效的基础资源、数据存储服务、DevOps 流水线以及运维自动化服务等。
4987 4
浅谈基于 OpenStack 和 k8s 建设云原生研发基础设施
|
10月前
|
缓存 Linux Docker
【最新版正确姿势】Docker安装教程(简单几步即可完成)
之前的老版本Docker安装教程已经发生了变化,本文分享了Docker最新版安装教程,其他操作系统版本也可以参考官 方的其他安装版本文档。
10268 3
【最新版正确姿势】Docker安装教程(简单几步即可完成)
|
数据采集 测试技术
Selenium与WebDriver:Errno 8 Exec格式错误的多种解决方案
本文讨论了在使用Selenium和WebDriver自动化测试时常见的执行格式错误(Errno 8 Exec format error)问题。错误通常发生在运行ChromeDriver时,与兼容性或路径配置有关。文章提供了多种解决方案,包括手动更改路径、更新或重新安装webdriver-manager包、下载特定版本的ChromeDriver、修改driver_cache.py文件。此外,还介绍了如何结合代理IP技术使用Selenium进行网页抓取,以提高效率和成功率。示例代码展示了如何配置代理IP并使用Selenium访问网站。通过这些方法,用户可以有效解决执行格式错误,并提高网页自动化测试
1286 1
Selenium与WebDriver:Errno 8 Exec格式错误的多种解决方案
|
传感器 机器人 API
NVIDIA Jetson TX1,TX2,TX2 NX,AGX Xavier 和 Nano开发板GPIO口配置及应用
NVIDIA Jetson TX1,TX2,TX2 NX,AGX Xavier 和 Nano开发板GPIO口配置及应用
|
关系型数据库 MySQL 数据库
【MySQL】:超详细MySQL完整安装和配置教程
【MySQL】:超详细MySQL完整安装和配置教程
41737 5
|
存储 人工智能 关系型数据库
MySQL 8.0 字符集与比较规则介绍
我们都知道 MySQL 8.0 与 MySQL 5.7 的区别之一就是默认字符集从 latin1 改成了 utf8mb4 ,除此之外,MySQL 8.0 下的字符集和比较规则还有没有其他变化呢?本篇文章我们一起来学习下。
787 1
|
消息中间件 Java 数据处理
揭秘Apache Flink的Exactly-Once神技:如何在数据流海中确保每条信息精准无误,不丢不重?
【8月更文挑战第26天】Apache Flink 是一款先进的流处理框架,其核心特性 Exactly-Once 语义保证了数据处理的精准无误。尤其在金融及电商等高要求场景下,该特性极为关键。本文深入解析 Flink 如何实现 Exactly-Once 语义:通过状态管理确保中间结果可靠存储;利用一致的检查点机制定期保存状态快照;以及通过精确的状态恢复避免数据重复处理或丢失。最后,提供一个 Java 示例,展示如何计算用户访问次数,并确保 Exactly-Once 语义的应用。
389 0
|
存储 运维 监控
带你从概念、指标、标准这3方面了解所谓的数据中心。
带你从概念、指标、标准这3方面了解所谓的数据中心。
773 0