rfc2047电子邮件主题中的多个编码字

时间:2013-03-07 05:59:56

标签: oracle email

我需要发送一封主题包含西里尔字母的电子邮件。但由于邮件服务器和/或客户端的某些问题,我的收件人有时会收到错误的信件。我总是以windows-1251编码发送电子邮件,但有时邮件客户端会以另一种编码(KOI-8R)显示字母的主题和发件人,而我们的用户无法理解该邮件。 我尝试使用RFC 2047标准中描述的编码字标签。例如,电子邮件中的“我的主题”字段现在看起来像:

Subject: =?WINDOWS-1251?B?wiDt5eTw4PUg8vPt5PD7IOL75PD7IOIg4+Xy8OD1IPL78P/yIOIg4uXk8OAg/+Tw?=
=?WINDOWS-1251?B?4CDq5eTw4C4gwvvw4uDiIPEg4vvk8Psg4iDy8+3k8OUg4+Xy?=
=?WINDOWS-1251?B?8PssIOL78vDzIOL75PDu6SD/5PDgIOrl5PDgLCDi+/Lw8yDj?=
=?WINDOWS-1251?B?5fLw7ukg4vvk8OUg7O7w5PMsIP/k8OAg4iDi5eTw4Cwg4vvk?=
=?WINDOWS-1251?B?8PMg4iDy8+3k8PMu?=

这些行由Oracle函数UTL_ENCODE.MIMEHEADER_ENCODE生成。

所有邮件客户端(Lotus Notes,gmail.com)仅显示此类电子邮件主题的第一行(仅前48个符号)。 我的邮件主题有什么问题?

1 个答案:

答案 0 :(得分:5)

问题是,根据RFC 2822,您没有正确折叠。要在标题中创建多行字段,每行必须以空格开头。

您需要做的是:

replace(UTL_ENCODE.MIMEHEADER_ENCODE(subject, 'UTF8', UTL_ENCODE.BASE64), UTL_TCP.CRLF, UTL_TCP.CRLF || ' ')

这可以解决您的问题。