【问题标题】:rfc2047 multiple encoded-word in email subjectrfc2047 电子邮件主题中的多个编码字
【发布时间】:2013-02-22 05:41:05
【问题描述】:

我需要发送一封主题包含西里尔字母的电子邮件。但是由于邮件服务器和/或客户端的一些问题,我的收件人有时会收到不正确的信件。我总是以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 个符号)。 我的邮件主题有什么问题?

【问题讨论】:

    标签: oracle email


    【解决方案1】:

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

    你需要做的是:

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

    这应该可以解决您的问题。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-07-23
      • 2014-05-24
      • 2011-11-20
      • 2011-06-21
      • 2018-11-09
      • 1970-01-01
      • 2021-08-16
      • 2017-04-01
      相关资源
      最近更新 更多