毕业论文——基于CS的电子邮件简单收发系统设计与实现.doc

上传人:滴答 文档编号:1279540 上传时间:2019-01-27 格式:DOC 页数:28 大小:1.07MB
下载 相关 举报
毕业论文——基于CS的电子邮件简单收发系统设计与实现.doc_第1页
第1页 / 共28页
毕业论文——基于CS的电子邮件简单收发系统设计与实现.doc_第2页
第2页 / 共28页
毕业论文——基于CS的电子邮件简单收发系统设计与实现.doc_第3页
第3页 / 共28页
毕业论文——基于CS的电子邮件简单收发系统设计与实现.doc_第4页
第4页 / 共28页
毕业论文——基于CS的电子邮件简单收发系统设计与实现.doc_第5页
第5页 / 共28页
点击查看更多>>
资源描述

1、 基于 C/S的电子邮件简单收发系统设计与实现 摘 要 电子 邮件作为互联网中交换信息广泛的通信工具之一,如今都已被广大用户接受 。 早期的电子邮件只是从一个计算机终端向另外一个计算机终端传送文本信息,而现在的电子邮件不仅可以发送文本信息,还可以传送声音、图片、文档等多种信息 。 很多邮件邮件客户端软件不断地被用户利用起来,例如 outlook, Foxmail,但是这些邮件客户端对于很多用户来说却过于复杂。 为了方便用户快捷地收发邮件,本课题利用 SMTP 协议和 POP3 协议, 经过前期对系统的需求分析和对相关协议的了解,设 计并实现 了简单的电子邮件收发系统。 为了保证本系统功能的完整

2、性,在实现该系统过程中,设计了邮件用户注册模块,当用户首次使用本系统时,须注册一个邮件账号,然后才能进行其他的操作。作为一个电子邮件客户端,邮件的发送与收取是其核心功能,本系统 邮件发送块实现电子邮件的发送,支持 邮件的单个发送和群发 ,在 邮件收取块,实现了电子邮件的简单收取。另外还增加了地址薄管理块让用户更方便地管理自己的联系人, 对联系人进行 添加、修改、删除等 。 关键词: 电子邮件; SMTP; POP3; 邮件收发系统 Design and Implementation of Simple Email Receiving and Sending System Based on C/

3、S Abstract Email is the communication tool which is widely used in the internet to exchange information. Now it has been accepted by many people. In the early days, email is only used in transmitting pure text information from a computer terminal to another. But at present, it is not limited in this

4、, it can support many types of information, such as voice, picture, document and so on. Much software has been used by users. such as Outlook, Foxmail and so on. But they are too complex to many users. In order to send and receive email conveniently, a simple email sending and receiving system has b

5、een designed based on SMTP and POP3 protocol after requirement analysis and protocols learning. To prove integrality of the system, the block of accounts registering is necessary. When using this system first time, users should register one account. It has the kernel function of sending and receivin

6、g email. In the block of sending email, group sending is supported. In addition, there is an address management block. Key words: E-mail; SMTP; POP3; Mail Receiving and Sending System 第 1 页 1 引言 1.1 邮件客户端相关介绍 电子邮件 (Electronic Mail、 E-mai1)又称电子信箱,它是 种用电子手段提供信息交换的通信方式,是应用于网络上的使用最广泛的网络功能之一。到目前为止 ,可以说电子

7、邮件是 Internet 资源使用最多的一种服务, E-mail 不只局限于信件的传递,还可用来传递文件、声音及图形、图像等不同类型的信息。电子邮件不是“终端到终端”的服务 ,而 是被称为“存贮转发式” 的 服务 。 “存贮转发式” 正是电子信箱系统的核心,利用存贮转发可进行非实时通信,属异步通信方式。电子邮件的发送几乎是即时的并且可以一次发送给多个人 , 发送和接收主要通过 SMTP 协议和 POP3 协议来实现, 经过几十年的发展, 电子邮件系统 已经形成了完善的技术体系。 电子邮件系统是一种新型的信息系统,是通信技术和计算机技术结合的产物。电子邮件系统采用“存储转发”的机制来完成电子邮件

8、的 收发。邮件服务器处理发送和接收消息的事项,并在处理电子邮件的过程中与其他机器进行通信。 图 1 工作流程图 1.2 课题背景 随着互联网技术的迅猛发展,网络给人们带来了很多便利,比如人们借助于网络进行相互交流变得更加方便。电子邮件作为互联网中交换信息广泛的通信工具之一,如今都已被广大网民接受。在了解 RFC 底层协议的基础上, 本课题 开发了这个功能相对简单实用的邮件客户端程序。 1.3 现状分析 电子邮件来源于专有电子邮件系统 , 早在 Internet 流行以前,电子邮件就已经存在了,是在主机 -多终端的主从式体系中从一台计算机终端向另 一 台 计算机终端传送文本信息的相对简单的方法

9、下 发展起来的。经历了漫长的过程之后,它现在已经演变成为一个更加复杂并丰富得多的系统,可以传送声音、图片、 图像 、文档等多媒体信息,以至于如数据库或 账户 报告等更加专业化的文件都可以以 电子邮件附件的形式在网上分发。现在,电子邮件已成为许多商家和组织机构的生命血脉 , 用户可以通过电子邮件的讨论会进行项目管理,并且有时 还 根据快速 而且跨 洲际的电子邮件信息交换进行重要的决策行动。毫无疑问的是,第 2 页 Internet 扩展了其应用的范围 , 过去只能在其局域网上进行交谈的公司现在可以通过网络与他 们的客户、竞争伙伴 与 世界上的任何人进行通信和交流。一旦某个组织的电子邮件系统运行在

10、支持 TCP/IP 协议的网络上或具有支持两个Internet 邮件服务协议 SMTP(简单邮件传输协议 )和 POP(邮局协议 )之一的Internet 网关,它的邮件用户就能够连接到任何具有相似连接的电子邮件地址上了,并且不论其电子邮件 账户 在何处 。 2 电子邮件相关协议 开发邮件客户端程序,就不得不用到 RFC822 邮件格式、 SMTP 协议和 POP3协议。 RFC822 定义了用于电子邮件报文的格式,即 RFC822 定义了 POP3、 SMTP以及其他电子 邮件传输协议所提交、传输的内容; POP3 是因特网上传输邮件的第一个协议,也是一个离线协议; SMTP 是 Inter

11、net 上传输电子邮件的标准协议,用于提交和传送电子邮件,规定了主机之间传输电子邮件的标准交换格式和邮件在链路层上的传输机制。 2.1 RFC822邮件格式 RFC822 中对电子邮件的格式加以定义,内容全部由 ASCII 字符组成,就是通常所说的文本文件,因而标准将它称为 Internet 文本信件 (Internet Text Messages)。为了支持多媒体文档的传输, 1996 年又发表了一系列的关于MIME(Multipurpose Internet mail Extensions)格式的定义。 RFC822 定义的邮件格式由两部分组成:邮件头(也称信封)和邮件内容。邮件头包括与传

12、输、投递邮件有关的信息;邮件内容包括标题和正文。 2.2 SMTP协议 SMTP( Simple Mail Transfer Protocol)简单邮件传输协议 , 是目前使用最广泛的发送电子邮件的 协议。 SMTP 通常用于把电子邮件从客户机传输到服务器,以及从某一服务器传输到另一个服务器。 2.2.1 SMTP协议简介 简单邮件传输协议( SMTP)的目标是可靠高效地传 送邮件,它独立于传送子系统而且仅要求一条可以保证传送数据单元顺序的通道。 SMTP 的一个重要特点是它能够在传送中接力传送邮件,传送服务提供了进程间通信环境( IPCE), 该环境可以包括一个网络,几个网络或一个网络的子网

13、。传送系统(或 IPCE)不是一对一的 , 进程可能直接和其它进程通过已知的 IPCE 通信。邮件是一个应用程序或进程间通信 , 邮件可以通过连接在不同 IPCE 上的进程跨网络进行邮件传送 , 更特别的是,邮件可以通过不同网络上的主机 进行 接力式传送。 SMTP 设计基于以下通信模型:针对用户的邮件请求,发送 SMTP 与接 收 SMTP之间建立一个双向传送通道。接收 SMTP 可以是最终接收者也可以是中间传送者。第 3 页 SMTP 命令由发送 SMTP 发出,由接收 SMTP 接收,而应答则反方 向 传送。 一旦传送通道建立, SMTP 发送者发送 MAIL 命令指明邮件发送者。如果

14、SMTP接收者可以接收邮件则返回 OK 应答。 SMTP 发送者再发出 RCPT 命令确认邮件是否接收到。如果 SMTP 接收者接收,则返回 OK 应答;如果不能接收到,则发出拒绝接收应答(但不中止整个邮件操作),双方将如此重复多次。当接收者收到全部邮件后会接收到特别的序列,如果接收者成功处理了邮件,则返 回 OK 应答。 SMTP 提供传送邮件的机制,如果接收方与发送方连接在同一个传送服务下时,邮件可以直接由发送方主机传送到接收方主机;当两者不在同一个传送服务下时,通过中继 SMTP 服务器传送 , 为了能够对 SMTP 服务器提供中继能力,它必须拥有最终目的主机地址和邮箱名称。 SMTP

15、的工作过程有一下几个过程有:( Mail)基本发送过程,向前传送邮件,确认邮箱名称和扩展邮件列表,发送到终端和打开关闭交换等。 2.2.2 SMTP的命令与应答 SMTP 定义了 14 个命令,它们是: HELO MAIL FROM: RCPT TO: DATA RSET SEND FROM: SOML FROM: SAML FROM: VRFY EXPN HELP NOOP QUIT TURN 其中使得 SMTP 工作的基本的命令有 7 个,分别为: HELO, MAIL, RCPT, DATA,REST, NOOP 和 QUIT。 下面分别介绍如下 : HELO-发件方 向 收件方 问候

16、, 命令 后面是发件人的服务器地址或标识。收件方回答 OK 时标识自己的身份。问候和确认过程表明两台机器可以进行通信,同时状态参量被复位,缓冲区被清空。 第 4 页 MAIL-这个命令用来开始传送邮件,它的后面跟随发件方邮件地址(返回邮件地址)。它也用来当邮件无法送达时,发送失败通知。为保证邮件的成功发送,发件方的地址应是被对方或中间转发方同意接受的 , 这个命令 会清空有关的缓冲区,为新的邮件做 好 准备。 RCPT -这个命令告诉收件方收件人的邮箱。当有多个收件人时,需要多次使用该命令,每次只能指明一个人。如果接收方服务器不同意转发这个地址的邮件,它必须报 550 错误代码通知发件方 ;

17、如果服务器同意转发,它要更改邮件发送路径,把最开始的目的地(该服务器)换成下一个服务器。 DATA-收件方把该命令之后的数据作为发送的数据。数据被加入数据缓冲区中,以单独一行是 “.“的行结束数据。结束行对于接收方意味 着 立即开始缓冲区内的数据传送,传送结束后清空缓冲 区 ; 如果传送接受,接收方回复 OK。 REST-这个命令用来通知收件方复位,所有已存入缓冲区的收件人数据 、 发件人数据和待传送的数据都必须清除,接收方必须回答 OK。 NOOP-这个命令不影响任何参数,只是要求接收方回答 OK, 不会影响缓冲区的数据。 QUIT-SMTP 要求接收方必须回答 OK,然后中断传输 。 在收

18、到这个命令并回答 OK 前,收件方不得中断连接,即使传输出现错误。发件方在发出这个命令并收到 OK 答复前,也不得中断连接。 对 SMTP 命令的响应是多样的,它确定了在邮件传输过程中请求和处理的同步,也保证了发送 SMTP 知道接收 SMTP 的状态。每个命令必须有且只有一个响应。 SMTP 响应由三位数字组成,其后跟一些文本。数字决定 了 下一个应该进入的状态,而文本对人是有意义的。三位的响应已经包括了足够的信息,不用再阅读文本,文本可以直接抛弃或者传递给用户。特别的是,文本是与接收和环境相关的,所以每次接收到的文本可能不同。在附录 E 中可以看到全部的响应码。正规的情况下,响应由下面序列

19、构成:三位的数字 ,一行文本和一个 ,或者也可以是一个多行响应。只有 EXPN 和 HELP 命令可以导致多行应答,然而对所有命令,多行 响应都是允许的。 SMTP 协议传送邮件的应答: 500 格式错误,命令不可识别(此错误也包括命令行过长) 501 参数格式错误 502 命令不可实现 503 错误的命令序列 504 命令参数不可实现 第 5 页 211 系统状态或系统帮助响应 214 帮助信息 220 服务就绪 221 服务关闭传输信道 421 服务未就绪,关闭传输信道(当必须关闭时,此应答可以作为对任何命令的响应) 250 要求的邮件操作完成 251 用户非本地,将转发向 450 要求的

20、邮件操作未完成,邮箱不可用(例如,邮箱忙) 550 要求的邮件操作未完成,邮箱不可用(例如,邮箱未找到,或不可访问) 451 放弃要求的操作;处理过程中出错 551 用户非本地,请尝试 452 系统存储不足,要求的操作未执行 552 过量的存储分配,要求的操作未执行 553 邮箱名不可用,要求的操作未执行(例如邮箱格式错误) 354 开始邮件输入,以 .结束 554 操作失败 2.3 POP3协议 POP3(Post office Protrol,邮局协议,第 3 版 )是 Internet 上传输电子邮件的第一个标准协议,也是一个离线协议。 POP3 为客户机提供了发送信任状(用户名和密码)

21、,这样就可以规范对电子邮件的访问。 POP3 是绝大多数邮件收发程序使用的协议,用户接收邮件时,一般都使用该协议。 2.3.1 POP3协议简介 POP3协议适用于 C/S 结构的脱机模型的电子邮件协议。在 POP3 协议下,当客户机与服务器连接并查询电子邮件时,被客户机所指定的将被下载的邮件都将被程序下载到客户机 , 下载后客户机可进行读取,修改等操作,而无需与服务器进一步交互。 POP3 客户向 POP3 服务器发送命令并等待响应, POP3 命令采用命令行形式,用 ASCII 码表示。 服务器响应是由一个单独的命令行组成,或多个命令行组成,响应第一行以ASCII 文本 +OK 或 -ER

22、R 指出相应的操作状态 。 在 POP3 协议中有三种状态, 即 认可状态,处理状态和更新状态。 当客户机与服务器建立联系时,一旦客户机提供了自己身份并成功确认,即由认可状态转入处理状态,在完成相应的操作后客户机发出 quit 命令,则进入第 6 页 更新状态,更新之后重返认可状态。 图 2 POP3 协议与三种状态间的关系 2.3.2 POP3的命令和应答 一般情况下,大多 数现有的 POP3 客户 端 与服务器执行采用 ASCII 明文发送用户名和口令,在认可状态等待客户连接的情况下,客户发出连接,并由命令user/pass 对在 网络 上发送明文用户名和口令给服务器 进行身份确认。一旦确

23、认成功,便转入处理状态。为了避免发送明文口令的问题,有一种新的认证方法,命令为 APOP,使用 APOP,口令在传输之前被加密。 当第一次与服务器连接时, POP3 服务器向客户机发送一个 ASCII 码问候,这个问候由一串字符组成对每个客户机是唯一的,与当时的时间有关,然后客户机把它的纯文本口令附加到从服务器接收到的字 符串之后,然后计算出结果字符串的 MD5 单出函数消息摘要,客户机把用户名与 MD5 消息摘要作为 APOP 命令的参数一起发送出去。 一 开始便是客户端与服务器的连接 , 端口设为 POP3 协议默认的 110。 客户端连接服务器成功后,服务器会返回以下信息: +OK 字符

24、 +OK 是 POP3 协议的返回信息。它的回应信息不像 SMTP 协议那样用丰富多变的数字表示,只有两个: +OK 或者 -ERR。其中, +OK 表示连接成功,而 -ERR 则表示连接失败。 接下来,客户端输入 USER 该命令告诉服务器你的用户名。注意,有些服务器会 区分大小写字母的。服务器返回 +OK 后,客户端输入 PASS 服务器返回 +OK后,还返回一些邮箱的统计信息,比如: +OK 1 message(s) 1304 byte(s) 不同的服务器返回的信息格式不太一样,所以我们可以用 STAT 命令来查看邮箱的情况。 STAT 命令的回应中有两个数字,分别表示邮件的数量和邮件的

25、大小。如果信箱里有信,就可以用 RETR 命令来获取邮件的正文。 RETR 命令的格式为: RETR 如果返回结果第一行是 +OK 信息,则表示成功。第二行起便是邮件的正文。最后一行和 SMTP 协议一样,是一个单独的英文句号,表示邮件的结尾部分。把邮件存储起来后要用 DELE 命令删除邮箱中的邮件,否则原有的邮件会继续保留在服务器上,一旦邮件一多,你的邮箱就爆了。 DELE 命令的格式为: DELE 如果删错了,可以用 RSET 命令来恢复所有已被删除的邮第 7 页 件。条件是你还没有退出,一旦退出, 邮件便不能恢复了 。全部完成以后,输入QUIT 命令就可以退出 POP3 服务器了。 表

26、1 pop3 协议命令码 命令 参数 状态 说明 USER 用户名 认可 此命令与 PASS 若成功,将导致状态转换 PASS 密码 认可 APOP 名字, Digest 认可 Digest是 MD5的消息摘要 STAT 名字, Digest 处理 请求服务器发送回关于邮箱的统计资料,如邮件数等 UIDL Msg# 处理 返回邮件的统一标志符, POP3 会话的每一个标志符都是唯一的 LIST Msg# 处理 返回邮件数量和每个邮件的大小 RETR Msg# 处理 返回由参数标志的邮件的全部文本 DELE Msg# 处理 服务器把由参数标识邮件记为删除,由QUIT 命令执行 RSET Msg#

27、 处理 服 务器将重置所有标记为删除的邮件,用于撤消 DELE 命令 TOP Msg# 处理 服务器返回参数标识的邮件前 n行内容, n是正整数 NOOP Msg# 处理 服务器返回一个肯定的响应 QUIT Msg# 更新 如果服务器处于处理状态,那么进入更新状态删除任何标记为删除的邮件 ;若处于认可状态,结束会话,不进行更新 3 系统需求分析 3.1 功能需求 作为一个电子邮件客户端,其核心功能是能够发送和接收邮件 ,其他附加功能如地址薄管理等也是不可少的。 第 8 页 3.1.1 邮件发送需求 主要要求能实现邮件的发送,不仅能实现单个发送而且 还能实现群发,同时要求能够发送附件。 3.1.

28、2 邮件 接收 需求 要求能实现电子邮件的接收,不仅能实现邮件文本的接收而且还能实现附件的接收,同时具有提示发件人,接收日期。 3.1.3 附加功能需求 附件功能主要有地址薄管理,用户能方便地实现对联系人的管理。 3.2 研究思路 根据需求,本系统按照如下几个模块的设计的。 3.2.1 用户注册块 用户只有在注册邮件账号后才能进行其他操作 。 3.2.2 邮件发送块 邮件发送 块主要实现邮件的发送,包括群发以及附件的发送。 3.2.3 邮件接收块 主要实现邮件文本信息的收取,包括附件的收取,同时具有其他如发件人等信息提示功能。 3.2.4 地址薄管 理块 主要是方便用户管理自己的联系人,主要是对联系人的增加,删除等。 4 系统总体功能 模块和系统总体流程 4.1 系统总体功能模块 系统的功能模块有账号 管理 模块、地址薄 管理 模块、写邮件模块与收邮件模块。

展开阅读全文
相关资源
相关搜索
资源标签

当前位置:首页 > 学术论文资料库 > 毕业论文

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。