计算机网络:应用层 —— 电子邮件
文章目录
- 电子邮件的起源与发展
- 电子邮件的组成
- 电子邮件协议
- 邮件发送和接收过程
- 邮件发送协议
- SMTP协议
- 多用途因特网邮件扩展MIME
- 电子邮件的信息格式
- 邮件读取协议
- 邮局协议POP
- 因特网邮件访问协议IMAP
- 基于万维网的电子邮件
电子邮件(E-mail)是因特网上最早流行的一种应用,并且仍然是当今因特网上最重要、最实用的应用之一。它通过电子方式发送和接收消息,极大地改变了人们的沟通方式。
电子邮件的起源与发展
电子邮件的历史可以追溯到20世纪60年代的阿帕网(ARPANET)。最初,电子邮件仅用于同一台计算机上的用户之间发送消息,后来逐渐发展为跨网络的通信工具。1971年,雷·汤姆林森(Ray Tomlinson)发明了现代电子邮件系统,并引入了@符号用于区分用户和服务器,奠定了电子邮件的基本格式。
随着互联网的普及,电子邮件成为全球范围内最常用的通信方式之一。如今,电子邮件不仅用于个人通信,还广泛应用于商业、教育、政府等多个领域。
传统的电话通信属于实时通信,存在以下两个缺点:
- 电话通信的主叫和被叫双方必须同时在场;
- 一些不是十分紧迫的电话也常常不必要地打断人们的工作或休息。
而电子邮件与邮政系统的寄信相似:
-
发件人将邮件发送到自己使用的邮件服务器
-
发件人的邮件服务器,将收到的邮件按其目的地址转发到收件人邮件服务器中的收件人邮箱
-
收件人在方便的时候访问收件人邮件服务器中自己的邮箱,获取收到的电子邮件。
电子邮件使用方便、传递迅速而且费用低廉。它不仅可以传送文字信息,而且还可附上声音和图像。由于电子邮件的广泛使用,现在许多国家已经正式取消了电报业务。在我国,电信局的电报业务也因电子邮件的普及而濒临消失。
电子邮件的组成
电子邮件系统采用客户/服务器方式。
电子邮件系统的三个主要组成构件:
-
用户代理(Mail User Agent, MUA):用户与电子邮件系统的接口,又称为电子邮件客户端软件。
-
邮件服务器(Mail Server):电子邮件系统的基础设施。因特网上所有的 ISP 都有邮件服务器,其功能是发送和接收邮件,同时还要负责维护用户的邮箱。
-
协议:电子邮件所需的协议,包括邮件发送协议(例如
SMTP)和邮件读取协议(例如POP3,IMAP)
电子邮件协议
邮件发送和接收过程

电子邮件的发送和接收过程涉及多个协议和服务器的协作,以下是其基本工作流程:
-
发送邮件:用户通过邮件客户端撰写邮件并点击“发送”按钮。邮件客户端使用
SMTP(简单邮件传输协议)将邮件发送到用户的邮件服务器。 -
邮件服务器之间的转发:发送方邮件服务器使用
SMTP协议将邮件转发到接收方邮件服务器。如果接收方服务器不可用,邮件将被暂时存储在发送方服务器的队列中,等待重试。 -
接收邮件:接收方邮件服务器接收邮件后,将其存储在用户的邮箱中。用户可以通过邮件客户端使用
POP3(邮局协议)或IMAP(互联网消息访问协议)协议从服务器下载或访问邮件。 -
邮件存储与管理:邮件存储在服务器的邮箱中,用户可以通过邮件客户端进行管理,如删除、回复、转发等操作。
邮件发送协议
SMTP协议
简单邮件传送协议SMTP(Simple Mail Transfer Protocol)用于发送电子邮件。当使用电子邮件客户端(如Outlook、Gmail等)发送一封电子邮件时,该客户端会使用 SMTP 协议将邮件发送到指定的 SMTP 服务器。然后,SMTP 服务器会负责将邮件路由到目标邮件服务器。
SMTP 客户与服务器之间,通过命令与应答的交互方式,最终实现 SMTP 客户发送邮件给 SMTP 服务器。
![![[简单邮件传送协议SMTP.png]]](https://i-blog.csdnimg.cn/direct/ccfd2ea4c82646dcb7135908b2acb744.png)
-
客户端与服务器建立 TCP 连接。
-
客户端发送
HELO或EHLO命令,标识自己的身份。 -
客户端发送
MAIL FROM命令,指定发件人地址。 -
客户端发送
RCPT TO命令,指定收件人地址。 -
客户端发送
DATA命令,开始传输邮件内容。 -
邮件传输完成后,客户端发送
.表示结束,服务器返回响应。 -
客户端发送
QUIT命令,向服务器请求断开连接。
多用途因特网邮件扩展MIME
SMTP协议只能传送ASCII码文本数据,不能传送可执行文件或其他的二进制对象。SMTP 不能满足传送多媒体邮件(例如带有图片、音频或视频数据)的需要。并且许多其他非英语国家的文字(例如中文、俄文、甚至带有重音符号的法文或德文)也无法用 SMTP 传送。
为解决 SMTP 传送非 ASCII 码文本的问题,提出了多用途因特网邮件扩展MIME(Multipurpose Internet Mail Extensions)
![![[多用途因特网邮件扩展MIME.png]]](https://i-blog.csdnimg.cn/direct/a385b77849a4465fa6555a918dfccebb.png)
-
增加了5个新的邮件首部字段,这些字段提共了有关邮件主体的信息。
-
定义了许多邮件内容的格式,对多媒体电子邮件的表示方法进行了标准化。
-
定义了传送编码,可对任何内容格式进行转换,而不会被邮件系统改变。
-
MIME不仅仅用于SMTP,也用于后来的同样面向ASCII字符的HTTP
电子邮件的信息格式
电子邮件的信息格式并不是由 SMTP 定义的,而是在 [RFC 822] 中单独定义的。这个 RFC 文档已在 2008 年更新为[RFC 5322]。一个电子邮件有信封和内容两部分。而内容又由首部和主体两部分构成。

邮件读取协议
常用的邮件读取协议有两个:邮局协议POP3和因特网邮件访问协议IMAP
POP3 和 IMAP4 都采用基于TCP连接的客户/服务器方式。POP3 使用熟知端口 110,IMAP4 使用熟知端口 143。
邮局协议POP
邮局协议 POP(Post Office Protocol),POP3 是其第三个版本,是因特网正式标准。用于从邮件服务器检索电子邮件。当使用电子邮件客户端从邮件服务器下载邮件时,该客户端会使用 POP3 协议。
POP3 协议允许将邮件从服务器下载到本地计算机,并从服务器上删除这些邮件。但用户只能以下载并删除方式或下载并保留方式,从邮件服务器下载邮件到用户方计算机。不允许用户在邮件服务器上管理自己的邮件。(例如创建文件夹,对邮件进行分类管理等)
POP3 基于 TCP 协议,工作在端口110(明文)或端口 995(加密)。其工作过程为:
-
客户端与服务器建立 TCP 连接。
-
客户端发送用户名和密码进行认证。
-
客户端可以列出邮件列表、下载邮件或删除邮件。
-
完成操作后,客户端发送
QUIT命令断开连接。
因特网邮件访问协议IMAP
因特网邮件访问协议 IMAP(Internet Message Access Protocol),IMAP4 是其第四个版本,目前还只是因特网建议标准。它是功能比 POP3 强大的邮件读取协议。用户在自己的计算机上就可以操控邮件服务器中的邮箱,就像在本地操控一样,而无需将邮件下载到本地。因此 IMAP 是一个联机协议。
IMAP 基于 TCP 协议,工作在端口143(明文)或端口993(加密)。其工作过程为:
-
客户端与服务器建立 TCP 连接。
-
客户端发送用户名和密码进行认证。
-
客户端可以列出邮箱、选择邮箱、检索邮件、标记邮件等。
-
完成操作后,客户端发送
LOGOUT命令断开连接。
基于万维网的电子邮件
通过浏览器登录(提供用户名和口令)邮件服务器万维网网站就可以撰写、收发、阅读和管理电子邮件。这种工作模式与 IMAP 很类似,不同的是用户计算机无需安装专门的用户代理程序,只需要使用通用的万维网浏览器。
邮件服务器网站通常都提供非常强大和方便的邮件管理功能,用户可以在邮件服务器网站上管理和处理自己的邮件,而不需要将邮件下载到本地进行管理。
用户在发送和接收邮件时,与服务器之间都使用的是 HTTP 超文本传送协议,而不需要使用 SMTP 和 POP3协议。若用户使用的邮件服务器不同,则邮件服务器使用 SMTP 协议将邮件发送给另一个用户的邮件服务器。
相关文章:
计算机网络:应用层 —— 电子邮件
文章目录 电子邮件的起源与发展电子邮件的组成电子邮件协议邮件发送和接收过程邮件发送协议SMTP协议多用途因特网邮件扩展MIME 电子邮件的信息格式 邮件读取协议邮局协议POP因特网邮件访问协议IMAP 基于万维网的电子邮件 电子邮件(E-mail)是因特网上最早…...
zyNo.26
[GXYCTF2019]Ping Ping Ping(Web) 传/?ip1有ping回显,说明后端可能通过php参数接受了ip参数,并且拼接到了最终执行的命令里形成了ping -c 3$ip,这样可能存在一个命令注入漏洞 要判断是否符合 ping -c 3$ip …...
结构型模式 - 适配器模式 (Adapter Pattern)
结构型模式 - 适配器模式 (Adapter Pattern) 适配器模式是一种结构型设计模式,它允许将一个类的接口转换成客户希望的另一个接口,使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。 类适配器,适用于要适配的类是一个接口…...
Linux 驱动模块稳定性检测框架 - 概要设计
Linux 驱动模块稳定性检测框架 1. 设计目标 实时监控:检测 Linux 设备驱动模块运行状态,及时发现异常。数据采集:通过内核打点,收集关键运行数据,分析模块稳定性。异常检测:分析错误日志、性能指标&#…...
ui设计公司兰亭妙微分享:科研单位UI界面设计
科研单位的UI界面设计是一项至关重要的任务,它不仅关乎科研工作的效率,还直接影响到科研人员的用户体验。以下是对科研单位UI界面设计的详细分析: 一、设计目标 科研单位的UI界面设计旨在提升科研工作的效率与便捷性,同时确保科…...
c# —— StringBuilder 类
StringBuilder 类是 C# 和其他一些基于 .NET Framework 的编程语言中的一个类,它位于 System.Text 命名空间下。StringBuilder 类表示一个可变的字符序列,它是为了提供一种比直接使用字符串连接操作更加高效的方式来构建或修改字符串。 与 C# 中的 stri…...
OpenGL ES -> GLSurfaceView绘制点、线、三角形、正方形、圆(顶点法绘制)
XML文件 <?xml version"1.0" encoding"utf-8"?> <com.example.myapplication.MyGLSurfaceViewxmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"…...
React + TypeScript 全栈开发最佳实践
React TypeScript 全栈开发最佳实践 一、环境搭建与项目初始化 node.js和npm的安装请参考我的文章。 1.1 脚手架选择与工程创建 # 使用Vite 5.x创建ReactTS项目(2025年主流方案) npx create-vitelatest my-app --template react-ts cd my-app npm in…...
AndroidAOSP定制隐藏某个应用的图标
AndroidAOSP定制隐藏某个应用的图标 1.前言: 之前在做AOSP定制的时候需要隐藏某些App的图标,或者默认不显示某个定制的App图标,这样可以让用户感觉不到已经安装了某个App,或者在做系统定制的时候需要修改桌面icon,有些系统的App图标默认不需要显示&…...
最小化重投影误差求解PnP
问题描述 已知n个空间点 P i [ x i , y i , z i ] T P_i[x_i,y_i,z_i]^T Pi[xi,yi,zi]T,其投影的像素坐标 p i [ u i , v i ] T p_i[u_i,v_i]^T pi[ui,vi]T求相机的位姿R,T。 问题分析 根据相机模型,像素点和空间点的位置…...
玩转Docker | 使用Docker部署IT-tools工具箱
玩转Docker | 使用Docker部署IT-tools工具箱 前言一、 IT-tools介绍简介主要特点二、系统要求环境要求环境检查Docker版本检查检查操作系统版本三、部署IT-tools服务下载镜像创建容器检查容器状态检查服务端口安全设置四、访问IT-tools应用五、测试与使用六、总结前言 在信息技…...
unity学习52:UI的最基础组件 rect transform,锚点anchor,支点/轴心点 pivot
目录 1 image 图像:最简单的UI 1.1 图像的基本属性 1.2 rect transform 1.3 image的component: 精灵 → 图片 1.4 修改颜色color 1.5 修改材质 1.6 raycast target 1.7 maskable 可遮罩 1.8 imageType 1.9 native size 原生大小 2 rect transform 2.1 …...
【Python系列】PYTHONUNBUFFERED=1的作用
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...
DeepSeek-R1技术全解析:如何以十分之一成本实现OpenAI级性能?
一、现象级爆火背后的技术逻辑 2025年1月20日,中国AI公司深度求索(DeepSeek)发布新一代大模型R1,其性能直接对标OpenAI的o1版本,但训练成本仅为后者的1/20(600万美元 vs. 1.2亿美元)࿰…...
Linux中的cgdb的基本使用
1.cgdb的简介 Linux中的cgdb是一个基于GDB(GNU Debugger)的图形化调试前端,它结合了GDB的命令行界面功能和代码查看窗口,为开发者提供了一个更为直观的调试体验。 cgdb的作用和功能: 直观调试体验:cgdb提供…...
Qt layout
文章目录 Qt layout**关键机制****验证示例****常见误区****最佳实践****总结**关键点总结:示例代码说明:结论: Qt layout 在 Qt 中,当调用 widget->setLayout(layout) 时,layout 的父对象会被自动设置为该 widget…...
解决idea2019创建springboot项目爆红的问题
通过spring Initializr创建springboot项目时,由于idea版本太低,创建完成后需要手动修改pom.xml,对小白不太友好 一个简便的方法,配置好pom.xml文件的各个版本: 在 https://start.aliyun.com/ 上选择好后复制pom.xml代…...
DeepSeek 提示词:基础结构
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
自动驾驶两个传感器之间的坐标系转换
有两种方式可以实现两个坐标系的转换。 车身坐标系下一个点p_car,需要转换到相机坐标系下,旋转矩阵R_car2Cam,平移矩阵T_car2Cam。点p_car在相机坐标系下记p_cam. 方法1:先旋转再平移 p_cam T_car2Cam * p_car T_car2Cam 需要注…...
[实现Rpc] 客户端 | Requestor | RpcCaller的设计实现
目录 Requestor类的实现 框架 完善 onResponse处理回复 完整代码 RpcCaller类的实现 1. 同步调用 call 2. 异步调用 call 3. 回调调用 call Requestor类的实现 (1)主要功能: 客户端发送请求的功能,进行请求描述对服务器…...
flutter: table calendar笔记
pub dev:table_calendar 3.2.0 我来详细解释 TableCalendar 是如何根据不同的 CalendarFormat 来显示界面的。主要逻辑在 CalendarCore 中实现。 核心逻辑分为以下几个部分: 页面数量计算 - _getPageCount 方法根据不同格式计算总页数: in…...
smolagents学习笔记系列(五)Tools-in-depth-guide
这篇文章锁定官网教程中的 Tools-in-depth-guide 章节,主要介绍了如何详细构造自己的Tools,在之前的博文 smolagents学习笔记系列(二)Agents - Guided tour 中我初步介绍了下如何将一个函数或一个类声明成 smolagents 的工具&…...
axios几种请求类型的格式
Axios 是一个基于 Promise 的 HTTP 客户端,广泛用于浏览器和 Node.js 中发送 HTTP 请求。它支持多种请求格式,包括 GET、POST、PUT、DELETE 等。也叫RESTful 目录 一、axios几种请求类型的格式 1、get请求 2、post请求 3、put请求 4、delete请求 二…...
架构设计系列(六):缓存
一、概述 在应用对外提供服务的时候其稳定性,性能会受到诸多因素的影响。缓存的作用是将频繁访问的数据缓存起来,避免资源重复消耗,提升系统服务的吞吐量。 二、缓存的应用场景 2.1 客户端 HTTP响应可以被浏览器缓存。我们第一次通过HTTP请…...
个人电脑小参数GPT预训练、SFT、RLHF、蒸馏、CoT、Lora过程实践——MiniMind图文版教程
最近看到Github上开源了一个小模型的repo,是真正拉低LLM的学习门槛,让每个人都能从理解每一行代码, 从零开始亲手训练一个极小的语言模型。开源地址: GitHub - jingyaogong/minimind: 🚀🚀 「大模型」2小时…...
MySQL 中的事务隔离级别有哪些?MySQL 默认的事务隔离级别是什么?为什么选择这个级别?数据库的脏读、不可重复读和幻读分别是什么?
MySQL 中的事务隔离级别有哪些? 1. 读未提交(Read Uncommitted) 特点:一个事务可以读取另一个事务未提交的数据。如果一个事务对数据进行了修改但尚未提交,其他事务仍能读取到这些未提交的修改。优缺点: …...
格式工厂 FormatFactory v5.18.便携版 ——多功能媒体文件转换工具
格式工厂 FormatFactory v5.18.便携版 ——多功能媒体文件转换工具 功能:视频 音频 图片 文档PDF格式 各种转换,同格式调整压缩比例,调整大小 特色:果风图标 好看; 支持多任务队列,完成自动关机 下载地址࿱…...
python爬虫学习第十一篇爬取指定类型数据
最近在学习Python爬虫的过程中,尝试用爬虫获取指定类型的数据。今天,我想和大家分享一下我的实践过程和遇到的问题。 一、实现目标 目标是从一个网站的API接口获取不同类型的食品数据。 比如,第一步我想获取汉堡、小食、甜品等不同类型的数…...
Android 实现 RTMP 推流:快速集成指南
简介 在 Android 设备上实现 RTMP 推流,可以用于直播、远程监控等应用场景。本文将基于 rtmp-rtsp-stream-client-java 库,介绍如何在 Android 端快速集成 RTMP 推流,包括权限管理、相机预览、推流控制等关键步骤。 步骤 1. 配置 Maven 仓库 在 settings.gradle.kts 中添…...
KafkaTool
Offset Explorer 第一次打开需要配置kafka相关配置连接 随便先启动一个Kafka(先启动zookeeper) 设置key value 记得刷新...
