- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我有一个 UTF-8 编码的 XML 文件,它作为附件通过电子邮件发送。当电子邮件收件人打开电子邮件并保存附件时,XML 文件不再是 UTF-8(而是报告 ANSI 编码)。在这种情况下,收件人使用了 Microsoft Outlook(如果重要的话)。
我在无法依赖合适的 MIME 库的可用性的环境中进行编程,所以我需要了解我哪里出错了。
在通过电子邮件发送 XML 文件之前,在服务器上创建它之后,我可以使用 Linux file 命令看到它是一个 UTF-8 文件。除此之外,XML 还有一个版本头 (这与我的问题并不真正相关,但为了完整起见,我将其包括在内)。我很确定我通过电子邮件发送文件的代码是这里的问题,但我不确定执行此操作的“正确”方法。
我发送的标题是:
"Mime-Version" "1.0"
"Content-Type" "multipart/mixed; boundary="__==NAHDHDH2.28ABSDJxjhkjhsdkjhd___"\n\n"
--__==NAHDHDH2.28ABSDJxjhkjhsdkjhd___\n
Content-Type: text/plain; charset="utf-8"; format=flowed\n
Content-Transfer-Encoding: 7bit\n\n
Please find attached the data file generated
--__==NAHDHDH2.28ABSDJxjhkjhsdkjhd___\n
Content-Type: text/plain; charset="utf-8"\n
Content-Disposition: attachment; filename="My_File_Name"\n\n
XML FILE CONTENTS GO HERE
--__==NAHDHDH2.28ABSDJxjhkjhsdkjhd___--\n
quoted-printable
, 8bit
或其他类型Content-Transfer-Encoding
这里?我已经尝试了所有这些,但它Content-Type: text/plain
XML 附件是否正确?
câu trả lời hay nhất
通过指定 text/plain
您基本上将控制权交给远程客户端的文本处理能力,这在这种特殊情况下显然是有限的。 XML 按照规范是 Unicode,因此通过选择更好的内容类型,您更有可能成功。试试 text/xml
hoặc application/xml
相反,甚至是完全不透明的 application/octet-stream
,这应该只允许接收者以字节对字节相同的形式将其保存在磁盘上。
内容传输编码根本不应该影响这种行为,但由于您似乎不清楚其重要性,这里是一个简短的讨论。
内容传输编码是完全透明的;它不会影响交付的内容或远程客户端可以用它做什么。选择哪种内容传输编码取决于数据的性质和需要传输的电子邮件系统的功能。如果它不是 8 位干净的,则需要一个 7 位 CTE 将其封装成。如果内容的行太长而无法放入 SMTP,则需要将其封装为较短的行。但是远程客户端将提取另一端封装内的任何内容。在任何情况下使用。
针对不同情况,内容传输编码具有层次结构:
7bit
如果您的数据完全是 7 位 ASCII 并且没有超过大约 990 个字符的行,则适用。然后它甚至可以在未经修改的情况下进行原始的旧 SMTP 传输。在没有任何明确的情况下 Content-Transfer-Encoding:
header ,这是根据标准的默认值(尽管您经常看到其中包含 8 位数据的内容,而没有明确的 CTE,甚至没有明确的 7bit
声明)。8bit
放宽了对数据 7 位清洁的要求。如果传输此消息的所有系统都支持 ESMTP 8BITMIME
扩展,这对于行长受限的数据应该没问题。nhị phân
另外允许无限的线长。理论上,您应该能够使用它来传递不受限制的内容,但实际上,当系统不严格遵守规范时,这似乎会引发故障。一个典型的症状是过长的线路在运输过程中被截断或折叠,破坏了有效载荷的完整性。为了避免此类问题(并更好地遵守互操作性标准的文字和精神),您最好采用以下方法之一。base64
接受不受限制的内容,但以一种满足限制行长度和严格限制的 7 位字符库的严格要求的格式对其进行编码。它将有效载荷扩展到原始大小的 4/3 以上。例子: ugqcA7R5cPq667vNaSifRUH9HsW00NqZ1gwICk0pNrUkXFpNIFOpbf3o
5ml8cqqSygkp8KBgPbHrqnDXvZTEBOkNo7ThE+BAvexa75Tm0Ebo/Yjl
y697pMp1+dnSlk3YTqxkPI9vqpple13dXLHlvnFDmSi0gqIMSwo7kUFD
SivAWhyCBR6tFO3lY1Pk6lz78+zgL28VthI72kVRkrWWtzoFef/4u5Ip
GR00CtsNNEJo01GAQGpkTNFT9U9Q/UI9CMGgaI9E9RkMaTDTQICBEyaE
woSCQOrNGA==
quoted-printable
类似地接受任意内容,但将所选字节编码为原始内容的 3 倍。当大部分输入是 ASCII 时,这是一个可以容忍的开销。换句话说,这适用于偶尔有非 ASCII 内容的粗略文本格式,例如使用 8 位编码的许多西方语言中的文本,或者像 HTML 这样的格式,其中 ASCII 标记在实际内容上占主导地位,几乎在任何情况下语。示例: h=C3=ABll=C3=B6 =
w=C3=B6rld
引用 printable 根本不难实现,并且似乎适合您的场景。
关于xml - 将 XML 文件作为附件通过电子邮件发送时对内容传输编码感到困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34999233/
我正在尝试学习Rust。我正在阅读一本书online,该书实现了unix程序cat。现在,我试图读取作为像cargo run file1.txt file2.txt这样的参数传递的文件的内容,但是程序
我在 GHC 8.0.1 中遇到了一个带有种类索引 (?) GADT 的奇怪情况,其中在类型与种类签名中引入 foralls 会产生不同的类型检查行为。 考虑以下数据类型: {-# LANGUAGE
我正在使用 Perl 5.10 开发应用程序,HTML::Mason和 Apache 2.2。这是我第一次在大型项目中使用 Perl 5.10。我每隔一段时间就会出现奇怪的行为。应用程序因一个非常奇怪
我正在尝试将文件上传到aws中的rust中,因为我使用的是 rusoto_s3 的s3 rust客户端,当这些部分从单个线程发送时,我设法使分段上传代码正常工作不是我想要的,我想上传大文件,并且希望能
Tôi là một lập trình viên xuất sắc, rất giỏi!