Заставьте quoted_printable_encode() работать на PHP4
Я пытаюсь использовать quoted_printable_encode() и [quoted_prinatble_decode(), но проблема в том, что мой сервер работает под управлением PHP4, и, согласно документам PHP, quoted_printable_encode() доступен только в PHP 5 >= 5.3.0. Кто-нибудь знает взлом или обходной путь, чтобы я мог использовать функцию кодирования
5 ответов
Согласно документации вы можете использовать imap_8bit, однако вам стоит подумать об обновлении до php5. Это было вокруг более 6 лет!
Я не могу отблагодарить вас всех за поддержку и помощь. Я полностью согласен, что мы должны перейти на PHP5 - но это для большой корпорации, в которой я работаю, и, как многие из вас знают, есть определенные вещи, которые ДОЛЖНЫ произойти, но не могут или не могут. В любом случае, я просто стажер, так что я буду делать, как говорится =)
Я понял -
function quoted_printable_encode($input, $line_max = 75) { // Quoted_printable_encode that works with php 4.x
$hex = array('0','1','2','3','4','5','6','7',
'8','9','A','B','C','D','E','F');
$lines = preg_split("/(?:\r\n|\r|\n)/", $input);
$linebreak = "=0D=0A=\r\n";
/* the linebreak also counts as characters in the mime_qp_long_line
* rule of spam-assassin */
$line_max = $line_max - strlen($linebreak);
$escape = "=";
$output = "";
$cur_conv_line = "";
$length = 0;
$whitespace_pos = 0;
$addtl_chars = 0;
// iterate lines
for ($j=0; $j<count($lines); $j++) {
$line = $lines[$j];
$linlen = strlen($line);
// iterate chars
for ($i = 0; $i < $linlen; $i++) {
$c = substr($line, $i, 1);
$dec = ord($c);
$length++;
if ($dec == 32) {
// space occurring at end of line, need to encode
if (($i == ($linlen - 1))) {
$c = "=20";
$length += 2;
}
$addtl_chars = 0;
$whitespace_pos = $i;
} elseif ( ($dec == 61) || ($dec < 32 ) || ($dec > 126) ) {
$h2 = floor($dec/16); $h1 = floor($dec%16);
$c = $escape . $hex["$h2"] . $hex["$h1"];
$length += 2;
$addtl_chars += 2;
}
// length for wordwrap exceeded, get a newline into the text
if ($length >= $line_max) {
$cur_conv_line .= $c;
// read only up to the whitespace for the current line
$whitesp_diff = $i - $whitespace_pos + $addtl_chars;
/* the text after the whitespace will have to be read
* again ( + any additional characters that came into
* existence as a result of the encoding process after the whitespace)
*
* Also, do not start at 0, if there was *no* whitespace in
* the whole line */
if (($i + $addtl_chars) > $whitesp_diff) {
$output .= substr($cur_conv_line, 0, (strlen($cur_conv_line) -
$whitesp_diff)) . $linebreak;
$i = $i - $whitesp_diff + $addtl_chars;
} else {
$output .= $cur_conv_line . $linebreak;
}
$cur_conv_line = "";
$length = 0;
$whitespace_pos = 0;
} else {
// length for wordwrap not reached, continue reading
$cur_conv_line .= $c;
}
} // end of for
$length = 0;
$whitespace_pos = 0;
$output .= $cur_conv_line;
$cur_conv_line = "";
if ($j<=count($lines)-1) {
$output .= $linebreak;
}
} // end for
return trim($output);
} // end quoted_printable_encode
Заставляет это работать. Я случайно вернулся сюда после того, как вы все опубликовали, поэтому, к сожалению, я не проверял ваши решения, но функция, описанная выше, работает просто отлично!
Спасибо всем еще раз!
public function quoted_printable($mesg){
$orders = unpack("C*", $mesg);
unset($mesg);
array_filter($orders, array($this, 'cb_qp'));
return implode($orders);
}
// Quoted-Printable Callback
private function cb_qp(&$byte){
$byte = ($byte > 126 || $byte == 61 || $byte == 37) ? sprintf('=%X', $byte) : pack("C", $byte);
}
// http://rolfrost.de/proglog.html?d=20130324
У вас установлен модуль IMAP? Как насчет использования imap_8bit()
вместо?
Лучшее, что можно сделать - это обновить до PHP 5. 4 не работает.
Если это действительно, действительно не вариант, на странице руководства, на которую вы ссылаетесь, есть несколько альтернатив (imap_8bit()
и некоторые альтернативные реализации в примечаниях, внесенных пользователем).