mime(multipurposeinternetmailextensions)多功能internet邮件扩充服务。
mime利用了一个事实就是,rfc822在消息体的内容中做了一点限制:唯一的限制就是只能使用简单的ascii文本。所以,mime信息由正常的internet文本邮件组成,文本邮件拥有一些特别的符合rfc822的信息头和格式化过的信息体(用ascii的子集来表示的附件)。这些mime头给出了一种在邮件中表示附件的特别的方法。
mime信息的剖析
一个普通的文本邮件的信息包含一个头部分(to:from:subject:等等)和一个体部分(hellomr.,等等)。在一个符合mime的信息中,也包含一个信息头并不奇怪,邮件的各个部分叫做mime段,每段前也缀以一个特别的头。mime邮件只是基于rfc822邮件的一个扩展。然而它有着自己的rfc规范集。
头字段
mime头根据在邮件包中的位置,大体上分为mime信息头和mime段头。(译者:mime信息头指整个邮件的头,而mime段头只每个mime段的头。)
mime信息头有:
mime-version:
这个头提供了所用mime的版本号。这个值习惯上为1.0。
content-type:
它定义了数据的类型,以便数据能被适当的处理。有效的类型有:text,
image,audio,video,applications,multipart和message。注意任何一个二进制附件都应该被叫做application/octet-stream。这个头的一些用例为:image/jpg,application/mswork,multipart/mixed,这只是很少的一部分。
content-transfer-encoding:
这是所有头中最重要的一个,因为它说明了对数据所执行的编码方式,客
户/mua将用它对附件进行解码。对于每个附件,可以使用7bit,8bit,
binary,quoted-printable,base64和custom中的一种编码方式。7bit编码是用在usascii字符集上的常用的一种编码方式,也就是,保持它的原样。8bit和binary编码一般不用。对人类可读的标准文本,如果传输要经过对格式有影响的网关时对其进行保护,可以使用quotedprintable。base64是一种通用方法,在需要决定使用哪一种编码方法时,它提供了一个不用费脑子的选择;它通常用在二进制,非文本数据上。注意,任何非7bit数据必须用一种模式编码,这样它就可以通过internet邮件网关!
content-id:
如果content-type是message/external-body或multipart/alternative时,这个
头就有用了。它超出了本文的范围。
content-description:
这是一个可选的头。它是任何信息段内容的自由文本描述。描述必须使用us-ascii码。
content-disposition:
一个试验性的头,它用于给客户程序/mua提供提示,来决定是否在行内显示附件或作为单独的附件。
mime段头(出现在实际的mime附件部分的头),除了mime-version头,可以拥有以上任何头字段。如果一个mime头是信息块的一部分,它将作用于整个信息体。例如,如果content-transfer-encoding显示在信息(指整个信息)头中,它应用于整个信息体,但是如果它显示在一个mime段里,它"只能"用于那个段中.