Add support to wp-mail.php for quoted-printable Content-Transfer-Encoding. Props Nazgul. fixes #2460

git-svn-id: https://develop.svn.wordpress.org/trunk@5188 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
rob1n 2007-04-06 02:57:46 +00:00
parent 28066a110c
commit 429613b2cc

View File

@ -24,10 +24,10 @@ for ($i=1; $i <= $count; $i++) :
$content = ''; $content = '';
$content_type = ''; $content_type = '';
$content_transfer_encoding = '';
$boundary = ''; $boundary = '';
$bodysignal = 0; $bodysignal = 0;
$dmonths = array('Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', $dmonths = array('Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec');
'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec');
foreach ($message as $line) : foreach ($message as $line) :
if (strlen($line) < 3) $bodysignal = 1; if (strlen($line) < 3) $bodysignal = 1;
@ -40,6 +40,12 @@ for ($i=1; $i <= $count; $i++) :
$content_type = explode(';', $content_type); $content_type = explode(';', $content_type);
$content_type = $content_type[0]; $content_type = $content_type[0];
} }
if (preg_match('/Content-Transfer-Encoding: /i', $line)) {
$content_transfer_encoding = trim($line);
$content_transfer_encoding = substr($content_transfer_encoding, 27, strlen($content_transfer_encoding)-14);
$content_transfer_encoding = explode(';', $content_transfer_encoding);
$content_transfer_encoding = $content_transfer_encoding[0];
}
if (($content_type == 'multipart/alternative') && (preg_match('/boundary="/', $line)) && ($boundary == '')) { if (($content_type == 'multipart/alternative') && (preg_match('/boundary="/', $line)) && ($boundary == '')) {
$boundary = trim($line); $boundary = trim($line);
$boundary = explode('"', $boundary); $boundary = explode('"', $boundary);
@ -111,11 +117,16 @@ for ($i=1; $i <= $count; $i++) :
$content = strip_tags($content[1], '<img><p><br><i><b><u><em><strong><strike><font><span><div>'); $content = strip_tags($content[1], '<img><p><br><i><b><u><em><strong><strike><font><span><div>');
} }
$content = trim($content); $content = trim($content);
if (stripos($content_transfer_encoding, "quoted-printable") !== false) {
$content = quoted_printable_decode($content);
}
// Captures any text in the body after $phone_delim as the body // Captures any text in the body after $phone_delim as the body
$content = explode($phone_delim, $content); $content = explode($phone_delim, $content);
$content[1] ? $content = $content[1] : $content = $content[0]; $content[1] ? $content = $content[1] : $content = $content[0];
echo "<p><b>Content-type:</b> $content_type, <b>boundary:</b> $boundary</p>\n"; echo "<p><b>Content-type:</b> $content_type, <b>Content-Transfer-Encoding:</b> $content_transfer_encoding, <b>boundary:</b> $boundary</p>\n";
echo "<p><b>Raw content:</b><br /><pre>".$content.'</pre></p>'; echo "<p><b>Raw content:</b><br /><pre>".$content.'</pre></p>';
$content = trim($content); $content = trim($content);