S/MIME的历史
要了解S/MIME,了解它的发展历史会有所帮助。第一版S/MIME是由许多安全供应商于1995年开发出来的。它是实现邮件安全性的几个规范之一。例如,Pretty Good Privacy(PGP)是实现邮件安全性的另一个规范。在S/MIME版本1推出的时候,安全邮件并没有公认的单一标准,但有几个相互竞争的标准。
1998年,随着S/MIME 2的推出,情况开始发生变化。与版本1不同的是,出于希望成为Internet标准的考虑,S/MIME 2被提交到Internet工程任务组(IETF)。通过这一步,S/MIME从许多可能的标准中脱颖而出,从而成为邮件安全标准的领跑者。S/MIME 2由两份IETF征求意见文档(RFC)组成:
1、建立邮件标准的RFC 2311(http://www.ietf.org/rfc/rfc2311.txt)
2、建立证书处理标准的RFC 2312(http://www.ietf.org/rfc/rfc2312.txt)。
这两份RFC共同提供了第一个基于Internet标准的框架,供应商可以按照该框架来提出可互操作的邮件安全解决方案。有了S/MIME 2,S/MIME开始成为邮件安全的标准。
1999年,为增强S/MIME功能,IETF提议使用S/MIME版本3。RFC 2632(http://www.ietf.org/rfc/rfc2632.txt) 建立在RFC 2311基础上,指定S/MIME邮件的标准;RFC 2633(http://www.ietf.org/rfc/rfc2633.txt) 增强了证书处理的RFC 2312规范。RFC 2634(http://www.ietf.org/rfc/rfc2634.txt) 通过向S/MIME添加其他服务扩展了总体功能,如安全回执、三层包装和安全标签。
S/MIME的功能
S/MIME 提供两种安全服务:
数字签名
邮件加密
这两种服务是基于S/MIME的邮件安全的核心。与邮件安全有关的其他所有概念都支持这两种服务。虽然整个邮件安全领域可能看上去很复杂,但这两种服务却是邮件安全的基础。在基本了解数字签名和邮件加密后,就会认识到其他概念是如何支持这些服务的。
本文将分别讲述这两种服务,然后介绍这两种服务如何一起工作。
数字签名
数字签名是更常用的S/MIME服务。顾名思义,数字签名是书面文档中具有法律意义的传统签名的数字形式。与具有法律意义的签名一样,数字签名也提供下列安全功能:
身份验证:通过签名来验证身份。它能够将该实体与其他实体区分开来,并证明它的唯一性,从而确认“您是谁”这个问题的答案。由于 SMTP 电子邮件中不存在身份验证,因此无法知道实际上是谁发送了邮件。数字签名中的身份验证使收件人可以知道邮件是声称已发送该邮件的那个人或组织发送的,从而解决了这一问题。
认可:签名的唯一性可防止签名的所有者否认签名。此功能称为“认可”。因此,签名所提供的身份验证提供了一种强制认可的手段。人们最熟悉的是书面合同上下文中认可的概念:已签名的合同是具有法律约束力的文档,要否认已通过身份验证的签名是不可能的。数字签名提供相同的功能,并且在某些领域中,逐渐被公认为与书面签名一样具有法律约束力。由于SMTP电子邮件不提供身份验证手段,因此无法提供认可功能。发件人很容易否认自己是某个SMTP电子邮件的所有者。
数据完整性:数字签名提供的另一安全服务是数据完整性。数据完整性是使数字签名成为可能的特定操作的结果。有了数据完整性服务,当经过数字签名的电子邮件的收件人验证数字签名时,他们可以确信所收到的电子邮件确实是被签名并发送出来的那封邮件,并且在传送过程中未发生改变。如果邮件在签名后的传送过程中发生了任何改变,该签名都将无效。这样,数字签名便能够提供书面签名所无法提供的保证功能,因为书面文档在经过签名后可能被改变。
重要提示: |
虽然数字签名提供数据完整性,但不提供保密性。与SMTP邮件类似,仅有数字签名的邮件将以明文形式发送,并且可能被其他人阅读。如果邮件是不透明签名的邮件,则会出现一定程度的混乱局面,这是因为虽然邮件是以base64编码的,但它仍然是明文形式。若要保护电子邮件的内容,必须使用邮件加密。 |
身份验证、认可和数据完整性是数字签名的核心功能。在它们的共同作用下,可以使收件人确信邮件来自发件人,并且所收到的邮件是所发送的邮件。
简单来说,数字签名的工作形式是在邮件发送时对电子邮件的文本执行签名操作,而在邮件被阅读时执行验证操作,如下图所示。
发送邮件时,执行签名操作所需要的信息只能由发件人提供。在签名操作中,通过捕获电子邮件并对邮件执行签名操作来使用此信息。此操作产生实际的数字签名。然后,此签名将附加到电子邮件中,并随同邮件一起发送。下图显示了邮件签名过程的顺序。
- 捕获邮件。
- 检索用来唯一标识发件人的信息。
- 使用发件人的唯一信息对邮件执行签名操作,以产生数字签名。
- 将数字签名附加到邮件中。
- 发送邮件。
由于此操作需要来自发件人的唯一信息,因此数字签名提供了身份验证和认可功能。此唯一信息可以证明邮件只能来自该发件人。
注意: |
任何安全机制都不是十全十美的。未经授权的用户可能获取用于数字签名的唯一信息,并冒充发件人。但是,S/MIME 标准可以处理这些情形,以显示未经授权的签名是无效的。 |
当收件人打开经过数字签名的电子邮件时,系统会对数字签名执行验证过程,并会从邮件中检索所包含的数字签名。还会检索原始邮件,然后执行签名操作,从而产生另一个数字签名。将邮件所包含的数字签名与收件人所产生的数字签名进行比较。如果签名匹配,则证明邮件确实来自所声称的那个发件人。如果签名不匹配,则将邮件标记为无效。下图显示了邮件验证过程的顺序。
- 接收邮件。
- 从邮件中检索数字签名。
- 检索邮件。
- 检索用来标识发件人的信息。
- 对邮件执行签名操作。
- 将邮件所附带的数字签名与收到邮件后所产生的数字签名进行比较。
- 如果数字签名匹配,则说明邮件有效。
重要提示: |
验证签名时所使用的发件人信息与对邮件进行签名时发件人所提供的信息不是同一个信息。通过这样一种方式叙述收件人使用的信息:使收件人在验证发件人的唯一信息时不必实际知道该信息,从而保护发件人的信息。 |
同时采用数字签名过程和数字签名验证过程可验证电子邮件发件人的身份,并确定已签名的邮件中数据的完整性。验证发件人身份会提供了其他认可功能,即防止已通过身份验证的发件人声称他们未发送过该邮件。数字签名是防止假冒身份和篡改数据的解决方案,而假冒和篡改这两种情况在基于标准SMTP的Internet电子邮件中均有可能出现。
邮件加密
邮件加密提供了针对信息泄露的解决方案。基于SMTP的Internet电子邮件并不确保邮件的安全性。SMTP Internet电子邮件可能被在发送过程中看到它或在所存储的位置查看它的任何人阅读。S/MIME已通过采用加密措施解决了这些问题。
加密是一种更改信息的方式,它使信息在重新变为可读或可理解的形式之前无法阅读或理解。
虽然邮件加密不像数字签名那样普遍使用,但是它确实解决了被许多人认为是Internet电子邮件最重大缺陷的问题。邮件加密提供两种特定的安全服务:
保密性:邮件加密用来保护电子邮件的内容。只有预期的收件人能够查看该内容,因而该内容是保密的,不会被可能收到或查看到该邮件的其他任何人知道。加密在邮件传送和存储过程中均提供保密性。
数据完整性:使用数字签名时,由于采用了使加密成为可能的特定操作,因此邮件加密提供了数据完整性服务。
重要提示: |
虽然邮件加密提供保密性,但是它不会以任何方式验证邮件发件人的身份。已加密但未签名的邮件与未加密的邮件一样,很容易被他人假冒为发件人。由于认可是身份验证的直接结果,因此邮件加密也不提供认可。虽然加密提供了数据完整性,但加密的邮件可能仅显示邮件自发送以来未发生过改变,而不提供有关邮件发件人的信息。要证明发件人的身份,邮件必须使用数字签名。 |
保密性和数据完整性提供了邮件加密的核心功能。它们确保了只有预期的收件人才能查看邮件,并且所收到的邮件就是所发送的邮件。
邮件加密通过在发送邮件时对邮件执行加密操作来使邮件的文本不可读。收到邮件时,通过在阅读邮件时执行解密操作来使文本再次成为可读文本,如下图所示。
加密操作在发送邮件时执行,它捕获电子邮件,并使用预期收件人所特有的信息来对邮件进行加密。加密的邮件替换了原始邮件,然后将邮件发送至收件人。下图显示了电子邮件加密过程的顺序。
- 捕获邮件。
- 检索用来唯一标识收件人的信息。
- 使用收件人的信息对邮件执行加密操作,以产生加密的邮件。
- 加密的邮件替换邮件中的文本。
- 发送邮件。
由于此操作需要有关收件人的唯一信息,因此邮件加密提供了保密性。只有预期的收件人具有执行解密操作时所需的信息。这确保了只有预期的收件人能够查看邮件,因为必须首先提供收件人的唯一信息,然后才能查看未加密的邮件。
重要提示: |
加密邮件时所使用的收件人信息与解密邮件时收件人所提供的信息不是同一个信息。通过这样一种方式叙述发件人使用的信息:使发件人在使用收件人的唯一信息时不会实际知道该信息,从而保护了收件人的信息。 |
当收件人打开加密邮件时,会对加密邮件执行解密操作。此时,将同时检索加密的邮件和收件人的唯一信息。然后,使用收件人的唯一信息对加密邮件执行解密操作。此操作返回未加密的邮件,然后该邮件将显示给收件人。如果邮件在传送过程中发生过改变,解密操作将失败。下图显示了解密电子邮件过程的顺序。
- 接收邮件。
- 检索加密邮件。
- 检索用来唯一标识收件人的信息。
- 使用收件人的唯一信息对加密邮件执行解密操作,以产生未加密的邮件。
- 将未加密的邮件返回给收件人。
注意: |
任何安全机制都不是十全十美的。未经授权的用户可能获取收件人的唯一信息,并使用该信息读取加密的邮件。但是S/MIME标准可以处理这些情形。 |
邮件加密和解密过程提供了电子邮件的保密性。此过程解决了Internet电子邮件中的重大缺陷:任何人都可以阅读任何邮件。
数字签名和邮件加密如何一起工作
数字签名和邮件加密并不是相互排斥的服务。每个服务都可解决特定的安全问题。数字签名解决身份验证和认可问题,而邮件加密则解决保密性问题。由于每个服务解决不同的问题,因此邮件安全策略通常同时需要这两个服务。这两个服务被设计为一起使用,因为它们分别针对发件人和收件人关系的某一方。数字签名解决了与发件人有关的安全问题,而加密则主要解决与收件人有关的安全问题。
同时使用数字签名和邮件加密时,用户会同时从这两个服务中受益。在邮件中采用这两个服务不会改变其中任何一个服务的处理过程:每个服务都按照本文档前面部分所讨论的那样工作。为了说明如何一起处理数字签名和邮件加密,下图显示了对电子邮件进行签名和加密的顺序。
- 捕获邮件。
- 检索用来唯一标识发件人的信息。
- 检索用来唯一标识收件人的信息。
- 使用发件人的唯一信息对邮件执行签名操作,以产生数字签名。
- 将数字签名附加到邮件中。
- 使用收件人的信息对邮件执行加密操作,以产生加密的邮件。
- 用加密后的邮件替换原始邮件。
- 发送邮件。
下图显示了对数字签名进行解密和验证的顺序。
- 接收邮件。
- 检索加密邮件。
- 检索用来唯一标识收件人的信息。
- 使用收件人的唯一信息对加密邮件执行解密操作,以产生未加密的邮件。
- 返回未加密的邮件。
- 将未加密的邮件返回给收件人。
- 从未加密的邮件中检索数字签名。
- 检索用来标识发件人的信息。
- 使用发件人的信息对未加密的邮件执行签名操作,以产生数字签名。
- 将邮件所附带的数字签名与收到邮件后所产生的数字签名进行比较。
- 如果数字签名匹配,则说明邮件有效。
三层包装邮件
S/MIME版本3的一个值得注意的增强功能是“三层包装”。三层包装的S/MIME邮件是指经过签名、加密、而后再次签名的邮件。这个额外的加密层为邮件提供了更高一层的安全性。当用户使用带有S/MIME控件的Outlook Web Access对邮件进行签名和加密时,邮件将自动进行三层包装。Outlook和Outlook Express并不对邮件进行三层包装,但它们可以读取这些邮件。
数字签名和邮件加密相互补充,并提供综合性的解决方案,以解决影响基于SMTP的Internet电子邮件的安全问题。
数字证书和邮件加密是S/MIME的核心功能。在邮件安全领域,最重要的支持性概念是公钥加密。公钥加密在S/MIME可见范围内产生数字签名,并对邮件进行加密。在公钥加密简介中,将介绍公钥加密及其与S/MIME的关系。
|