本文中讲解的 microsoft exchange server internet 协议
- 服务器端协议
- 客户端协议
疑难解答技巧
- 介绍和示例
- 协议命令和响应概述
- 协议记录
何处可以找到其它信息
- rfc 索引
本文中讲解的 microsoft exchange server internet 协议
microsoft® exchange server 从第一次发布时起,就支持 internet 协议。随着产品的发展,microsoft 在现有协议组中添加了一些新的协议,以及更多的功能。本文档介绍了 exchange server internet 协议,并提供了对这些 internet 协议进行疑难解答的基本指导方针。
首先要注意的是,exchange server 在实现这些 internet 协议时与 rfc 是 100% 兼容的,这一点很重要。下列表格列出了这些协议,以及 exchange server 的哪个版本对其提供支持。
| 协议 |
smtp |
http |
nntp |
ldap |
pop3 |
imap4 |
|---|---|---|---|---|---|---|
| exchange 4.0 |
* |
|||||
| exchange 5.0 |
* |
* |
* |
* |
* |
|
| exchange 5.5 |
* |
* |
* |
* |
* |
* |
这些协议可划分为两类:“服务器端协议”和“客户端协议”。服务器端协议通常是 exchange server 用来连接到另一台邮件服务器,并向其传送电子邮件的协议。客户端协议是客户端用来访问 exchange server 计算机上的电子邮件的协议。协议的这两个分组在某些情况下是重叠的,这在本文稍后部分的“协议命令和响应概述”一节中的 pop3 和 imap4 小节中进行了说明。
服务器端协议
简单邮件传输协议 (smtp) 是服务器端协议,它允许 microsoft exchange server 通过 internet 连接到另一个能使用 smtp 的服务器,以便传送邮件。此协议的细节在 rfc-821 中进行了概述。但重要的是讨论此协议的概念,以便了解它可能会出现的问题。此协议只概述了邮件是如何传送的,而并未包括邮件内容的详细信息。它是一个指导方针,说明了一个 smtp 主机应发出哪些命令,以及接收命令的主机为使邮件流出现,应如何解释这些命令。
microsoft 在其 exchange server(4.0 版)第一次发布时,就在一个通常称为 internet mail connector (imc) 的组件中,实现了 smtp 协议。在 exchange server 5.x 中,此组件被重命名为 internet mail service。internet mail service 是一个复杂的组件,它带有一个有不同职责的数组,这些职责包括建立和接收 tcp/ip 连接、将邮件从一种格式转换为另一种,以及附件的编码和解码。本文档介绍了通过 smtp 协议进行的 internet mail service 邮件传送和邮件接收。
客户端协议
exchange server 中包括的客户端协议为用户提供了访问其信息的更多方法。其目的是为用户提供一种方法,使其能在 internet 上任何地方,使用任何兼容客户机,从任何平台上发送和接收邮件。两个最常见的只读协议是 http 和 pop3。
超文本传输协议 (http) 是 web 浏览器(如 microsoft® internet explorer)使用的协议,用来查看 web 页和基于万维网的内容。在 microsoft® outlook web access (owa) 组件中,使用了 exchange server 的 http 实现。owa 使任何有 web 浏览器的用户能够发送和接收电子邮件、为公用文件夹提供内容,以及查看公用文件夹。
邮局协议 3 (pop3) 是在 exchange server 5.0 中提供的。它是一个只读协议,允许 pop3 客户端在 internet 上的任何地方连接到 exchange server 计算机,并将邮件下载到本地,以便阅读。该协议是只读协议,因为在 pop3 协议中没有发送电子邮件的定义。pop3 客户端使用 smtp 协议和 exchange server 计算机的 internet mail service 发送邮件。pop3 协议只提供对用户“收件箱”的访问。exchange server 将此协议作为信息存储的一项任务实现。
internet 消息访问协议 4 (imap4) 尽管与 pop3 类似,但允许用户访问他们的任何文件夹,而不仅仅是收件箱。出于此原因,它比 pop3 更复杂;但是它仍旧遵从相同的标准,是一个只读协议。和 pop3 一样,imap4 使用 smtp 发送电子邮件。imap4 也如信息存储过程那样运行。
轻型目录访问协议 (ldap) 是一个简单的协议,它允许客户端在 exchange 目录中查询几乎所有种类的信息。它最常用于访问邮箱属性,以便在写邮件时,发件人能够了解收件人的更多详细情况。ldap 协议不限制它自己的实现。它可用于读和写邮箱信息,或任何种类的基于目录的信息。exchange server 5.0 实现的 ldap 限于只读。在 5.5 版中,ldap 客户端能够对 exchange 目录进行读操作和写操作。ldap 服务器是 microsoft exchange 目录服务的一项功能。
网络新闻传输协议 (nntp) 通常称为“internet 新闻协议”,因为它包含从一台计算机向另一台计算机传输新闻条目的规则。此处提及的 nntp 是作为一个客户端/服务器端协议;但是它也包括基于服务器到服务器的新闻传送。exchange internet news service 与公用信息存储合作,提供 nntp 访问。
疑难解答技巧
介绍和示例
在从一台主机向另一台主机建立连接后,以上讨论的所有协议都管理一套规则,或一个对话。该连接是到接收主机上的特殊端口的 tcp 连接。tcp 连接是要求在可以传输或接收数据前建立一个会话的连接。当会话建立后,使用命令来来往往地发送数据。对话完成后,将放弃会话。以下是一个协议及其监听的 tcp 端口的列表。
| 协议 |
端口 |
|---|---|
| smtp |
25 |
| http |
80 |
| nntp |
119 |
| ldap |
389 |
| pop3 |
110 |
| imap4 |
143 |
解决协议疑难问题的第一步是验证您已建立了一个到主机的成功的 tcp 连接。解决这一问题的最简单方法是,使用 telnet 命令,连接到所需端口。不要用“ping”命令测试主机。 ping 实用程序不告诉您主机正在监听端口 25。它只是显示,一个低级数据包能够找到通往正确 ip 地址的途径。此外,许多公司阻止 ping 或 icmp 数据包,使其甚至不能进入公司的网络。解决所有这些协议问题的最好方法是使用 telnet 命令。要得到对 telnet 工作方式的感性认识,试着使用 telnet,连接到您的本地 exchange server 计算机端口 25。语法为:
例如:
以上的两个示例都能连接到端口 25,但第一个是最可靠的。在使用系统的 ip 地址进行系统寻址时,您可避免出现名称解析问题的可能性。以上示例应带出一个 telnet 窗口,和一条成功连接消息,表明您可以开始向主机发送邮件。这象征着主机在端口 25 上监听,您或许可以向主机发送一个 smtp 邮件。以上的示例与 exchange internet mail service 连接以便发送电子邮件时的情况类似。至此,internet mail service 开始向主机发送 smtp 命令,以便启动邮件传送。
所有这些协议的工作方式是相似的。它们全部包括发送到主机的命令,以及预期的回复。在您断定可与正确端口建立成功连接后,就可以开始检查命令发出时对主机的实际响应。
最佳测试方法是真正地使用 telnet 命令向主机发出命令。如果您确切地知道您需要发送什么内容,以及如何发送,或者您知道您的客户端/服务器端程序正在试图发送什么内容,那么这种方法是很有效的。问题是您能够看到所给的典型响应,但看不到主机正在发送的内容。
以下是一个发送给 smtp 主机的典型 telnet 会话示例。
如果您的浏览器不支持内嵌框,请单击此处在单独的页中查看。
- helo 命令发出,而且服务器对其响应,显示它理解并接受该命令。
- mail from 告知主机发件人是谁。服务器再次成功响应。
- rcpt to 告知主机要将此邮件传送给谁。
这些命令将在“协议命令和响应概述”一节中进一步讨论。
以下示例说明了一个测试 pop3 身份验证的 telnet 会话。
如果您的浏览器不支持内嵌框,单击此处,可在单独的页面中查看。
- user 命令(后面跟着适当的登录验证信息),用于登录到 pop3 邮箱。
- pass 命令发出获得访问权限的密码。
- exchange server 返回“+ok user successfully logged on”。
协议命令和响应概述
所有命令都以回车/换行 (cr/lf) 终止。(.tld 代表顶层域。)
| 命令 |
预期响应 |
说明 |
|---|---|---|
| helo |
250 ok |
开始主机间对话。 |
| mail from: <user@domain.tld> |
250 ok |
标识邮件的发件人。 |
| rcpt to: <user@domain.tld> |
250 ok |
标识邮件的收件人。 |
| data |
354 send data |
标识邮件数据的开始点。 |
| .(一个句号) |
250 ok |
标识邮件数据的结束点。 |
| quit |
221 |
终止会话。 |
| 命令 |
预期响应 |
说明 |
|---|---|---|
| user ntdomain/ntaccount/别名 |
+ok |
开始身份验证过程。 |
| pass nt_password |
+ok |
为 windows nt 帐户指定密码。 |
| list |
+ok |
列出可供下载的邮件。 |
| retr邮件号 |
邮件正文 |
检索“邮件号”对应的邮件正文。 |
| dele邮件号 |
+ok |
删除“邮件号”对应的邮件。 |
| quit |
+ok |
终止会话。 |
imap4
向 imap4 服务器发出的所有命令必须以命令标识符为前缀。此标识符是客户能够解释的,以便跟踪命令和响应对。
例如,当您的 imap 客户机发出本地 select 收件箱时,服务器的响应为本地 ok。
| 命令 |
预期响应 |
说明 |
|---|---|---|
| login ntdomain/ntaccount/别名密码 |
ok login |
登录到邮箱。 |
| select 文件夹 |
文件夹模式和 ok select |
选择要查看的文件夹。 |
| fetch 邮件号 |
邮件正文和 ok fetch |
按“邮件号”检索邮件。 |
| store 邮件标志\标志 |
ok store |
为邮件作删除或已读/未读标记。 |
| expunge |
ok |
删除所有作了标记的邮件。 |
| logout |
ok |
终止会话。 |
当命令被拒绝时,会得到一个 no 响应。
nntp
nntp 访问有两种模式:身份验证和匿名。身份验证需要以下列出的命令中的前两个。
| 命令 |
预期响应 |
说明 |
|---|---|---|
| authinfo user ntdomain/ntaccount/用户名 |
381 more info needed |
提供身份验证信息。 |
| authinfo pass密码 |
281 accepted |
提供身份验证密码。 |
| list |
组列表 |
列出所有可用组。 |
| group 组 |
分组规范 |
设置当前组。 |
| article 文章号 |
文章正文 |
按“文章号” 检索文章。 |
| quit |
205 |
终止会话。 |
协议记录
第二种疑难解答的方法仅适用于 exchange server。exchange server 为它的多数协议执行协议记录。当所涉及的协议的协议记录开启时,主机间的实际对话被转录为一个文本文件。这是疑难解答的最佳方法之一。它唯一的缺点是,有时,在有大量连接的情况下,难以确定哪个对话适用于您的问题。
可为 smtp、pop3、imap4 和 nntp 启用协议记录。以下是选自 internet mail service 的示例 smtp 协议日志:
以上的协议日志显示了连接到另一台 exchange server 计算机的 internet mail service。“>>>”和“<<<”显示了数据是从何方向而来。“>>>”暗示发送数据的是本地服务器。
启动 smtp 协议记录的步骤
- 启动 exchange server administrator 程序。
- 选择 internet mail service。在 file 菜单上选择 properties。
- 单击 diagnostic logging 选项卡。
- 选择 smtp protocol log,并将其设置为 maximum。
- 关闭 internet mail service 属性页。
- 停止并重新启动 internet mail service。
在协议记录开启的情况下,internet mail service 在 exchange server 计算机上的 exchsrvr\imcdata\log 子目录中创建一个 l000000#.log 文件。一定要记住,根据通过连接器的邮件量,这些 .log 文件会在硬盘上占用大量的空间。协议记录应仅用于解决特殊的问题,而在正常使用连接器时,应将其关闭。
启动 pop3、imap4 和 nntp 协议记录的步骤
- 在 exchange server 计算机上,使用 regedt32,运行注册表编辑器。
- 转到以下子项:
hkey_local_machine \system \currentcontrolset \services \msexchangeis \parameterssystem
- 将 \pop3_protocol_logging_level 的值更改为 1 到 4 之间的值(1 = 最小,4 = 最大)。
- 更改 \pop3_protocol_logpath 的值,使其指定您想要写日志文件的地方。
- 关闭 regedt32。
- 停止并重新启动信息存储服务,以便使日志记录生效。
- imap4 和 nntp 日志记录可在同一个注册表配置单元中找到,要想开启它们,可使用:
\imap4_protocol_logging
\nntp_protocol_logging
在协议记录开启的情况下,信息存储在所涉及的协议的注册表中指定的路径中,创建一个 l000000#.log 文件。默认情况下,在 exchsrvr\mdbdata 中创建该文件。与 smtp 协议记录相同的规则在此也适用:pop3、imap4 和 nntp 协议记录仅应用于解决特殊问题,在正常使用中,应将其关闭,以避免昂贵的管理开销。
何处可以找到其它信息
本文档介绍了解决 exchange server internet 协议问题的基本指导方针。本文档的“协议命令和响应概述”一节中的协议命令和响应表仅包含与选定的协议相关的部分命令列表。要得到完整的命令列表和语法的详细信息,最好的方法始终是查阅 rfc。
| 协议 |
rfc |
|---|---|
| smtp |
rfc-821, rfc-1869 |
| pop3 |
rfc-1939, rfc-1734 |
| imap4 |
rfc-2060, rfc-2088, rfc-1731 |
| nntp |
rfc-977 |
| ldap |
rfc-1777 |
© 1998 microsoft corporation. 版权所有。
本文档包含的信息代表了发布之日,microsoft corporation 对所讨论问题的当前看法。因为 microsoft 必须顺应不断变化的市场条件,故该文档不应被理解为 microsoft 一方的承诺,microsoft 不保证所给出的信息在发布之日以后的准确性。
本白皮书仅供参考。在本文档中,microsoft 不作任何明示的或默示的保证。
backoffice、backoffice 徽标和 microsoft 是 microsoft corporation 的注册商标。
此处提到的其它产品或公司名称可能是其各自所有者的注册商标。
microsoft corporation • one microsoft way • redmond, wa 98052-6399 • usa
,文章整理:西部数码--专业提供域名注册、虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!


