2010-12-03 5 views
1

Я пытаюсь использовать quoted_printable_encode() и [quoted_prinatble_decode(), но проблема в том, что мой сервер работает с PHP4, и, согласно документам PHP, quoted_printable_encode() доступен только на PHP 5 > = 5.3.0. Кто-нибудь знает о взломе или обходном пути, чтобы я мог использовать функцию кодированияСделать quoted_printable_encode() работать с PHP4

+2

Извините, не знаю, как вам помочь, но вы обязательно должны измениться на php5! php4 - это 100 в компьютерные годы! :) – Trufa

ответ

0

У вас установлен модуль IMAP? А как насчет использования imap_8bit()?

0

Лучшее, что нужно сделать, это обновление до PHP 5. 4: dead.

Если это действительно, на самом деле не вариант, то manual page you link to имеет несколько альтернатив (imap_8bit() и некоторые альтернативные реализации в примечаниях, внесенных пользователем).

2

В соответствии с документами вы можете использовать imap_8bit, однако вы должны действительно рассмотреть возможность обновления до php5. Он существует уже более 6 лет!

1

Я не могу поблагодарить всех вас за поддержку и помощь. Я полностью согласен с тем, что мы должны перейти на 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 

делает его работу. Мне довелось проверить это после того, как вы все разместили, так что, к сожалению, я не тестировал ваши решения, но функция выше работает просто отлично!

Спасибо всем снова!

+1

убедитесь, что вы пометили свой ответ как принятый - может быть полезно для кого-то еще, я думаю, и интересно увидеть полную реализацию. – Hamish

0
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