Anyone familiar with this class willing to help out. Would
  appreciate it.

when i run the following (example.php) script, i always get what looks
like the rfc822 body of the message within the e-mail, but never the 
html or text body body parts. first i'll show the output of the script, 
then the example.php script. html_mime_mail.class is attached.

notice how the mime-version definition and boundary is within the 
message body, also notice how the text/html part has base64 encoding? 
this is on netscape 6, but repeatable with outlook express.

again, thanks if you actually trace through this, or recognize the error 
otherwise. - eric

######## output (msg body) #########


MIME-Version: 1.0

Content-Type: multipart/mixed;

        boundary="=_2ad7f0cbb98266e56a24391bd135d9a4"

This is a MIME encoded message.

--=_2ad7f0cbb98266e56a24391bd135d9a4

Content-Type: multipart/alternative;

        boundary="=_22bf429aee349f53ea3e34f8bb0149b3"

--=_22bf429aee349f53ea3e34f8bb0149b3

Content-Type: text/plain; charset="iso-8859-1"

Content-Transfer-Encoding: base64

U3VjY2Vzcw==

--=_22bf429aee349f53ea3e34f8bb0149b3

Content-Type: text/html; charset="iso-8859-1"

Content-Transfer-Encoding: base64

PEhUTUw+PEJPRFkgQkFDS0dST1VORD1iYWNrZ3JvdW5kLmdpZj5lcmljZXJpY2VyaWM8L0JPRFk+

PC9IVE1MPg==

--=_22bf429aee349f53ea3e34f8bb0149b3--

--=_2ad7f0cbb98266e56a24391bd135d9a4--



######## example.php script #########


<?php
/***************************************
** Title.........: HTML Mime Mail class
** Version.......: 1.33
** Author........: Richard Heyes <[EMAIL PROTECTED]>
** Filename......: example.php3
** Last changed..: 24/10/2000
** Notes.........: Based upon mime_mail.class
**                 by Tobias Ratschiller <[EMAIL PROTECTED]>
**                 and Sascha Schumann <[EMAIL PROTECTED]>.
***************************************/

         error_reporting(63);
         include('class.html.mime.mail.inc');

/***************************************
** Example of usage.
***************************************/
         /***************************************
         ** Read the file background.gif into
         ** $backgrnd.
         ***************************************/

         /***************************************
         **
         ** !! Important !!
         **
         ** If running this script upon Windows
         ** then you may need to change the fopen()
         ** mode from 'r' to 'rb'.
         ** Thanks to Thomas Unger for this nugget.
         ***************************************/

         //$filename = 'background.gif';
         //$backgrnd = fread($fp = fopen($filename, 'r'), 
filesize($filename));
         //fclose($fp);

         /***************************************
         ** Read the file test.zip into $attachment.
         ***************************************/
         //$filename = 'example.zip';
         //$attachment = fread($fp = fopen($filename, 'r'), 
filesize($filename));
         //fclose($fp);

         /***************************************
         ** Create the mail object. Optional headers
         ** argument. Do not put From: here, this
         ** will be added when $mail->send
         ** Does not have to have trailing \r\n
         ** but if adding multiple headers, must
         ** be seperated by \r\n.
         ***************************************/
         $mail = new html_mime_mail('X-Mailer: Html Mime Mail Class');
                
         /***************************************
         ** If sending an html email, then these
         ** two variables specify the text and
         ** html versions of the mail. Don't
         ** have to be named as these are. Just
         ** make sure the names tie in to the
         ** $mail->add_html() command further down.
         ***************************************/
         $text = "Success";
         $html = "<HTML><BODY 
BACKGROUND=background.gif>ericericeric</BODY></HTML>";

         /***************************************
         ** Add the text, html and embedded images.
         ** Each embedded image has to be added
         ** using $mail->add_html_image() BEFORE
         ** calling $mail->add_html(). The name
         ** of the image should match exactly
         ** (case-sensitive) to the name in the html.
         ***************************************/
         //$mail->add_html_image($backgrnd, 'background.gif', 'image/gif');
         $mail->add_html($html, $text);

         /***************************************
         ** If not sending an html email, then
         ** this is used to set the plain text
         ** body of the email.
         ***************************************/
 
//$mail->set_body('ftfuygfyugyguilgulghlgjhlg'."\n\n\n".'jhlkgjguilguilguil 
ghjli');

         /***************************************
         ** This is used to add an attachment to
         ** the email.
         ***************************************/
         //$mail->add_attachment($attachment, 'example.zip', 
'application/octet-stream');

         /***************************************
         ** Set Character Set
         ***************************************/
         $mail->set_charset('iso-8859-1', TRUE);

         /***************************************
         ** Builds the message.
         ***************************************/
         $mail->build_message();

         /***************************************
         ** Sends the message. $mail->build_message()
         ** is seperate to $mail->send so that the
         ** same email can be sent many times to
         ** differing recipients simply by putting
         ** $mail->send() in a loop.
         ***************************************/
         $mail->send('TO NAME', '[EMAIL PROTECTED]', 'FROM NAME', 
'FROM ADDRESS', 'SUBJECT LINE');

?>

<?php
/***************************************
** Title.........: HTML Mime Mail class
** Version.......: 1.33
** Author........: Richard Heyes <[EMAIL PROTECTED]>
** Filename......: html_mime_mail.class
** Last changed..: 31/08/2000
** Notes.........: Based upon mime_mail.class
**                 by Tobias Ratschiller <[EMAIL PROTECTED]>
**                 and Sascha Schumann <[EMAIL PROTECTED]>.
**                 See http://www.heyes-computing.net/scripts/
**                 for full tar/zip if you haven't got one.
***************************************/

class html_mime_mail{

        var $mime;
        var $html;
        var $body;
        var $do_html;
        var $multipart;
        var $html_text;
        var $html_images;
        var $headers;
        var $parts;
        var $charset;
        var $charsetlist;

/***************************************
** Constructor function. Sets the headers
** if supplied.
***************************************/

        function html_mime_mail($headers = ''){

                $this->html_images = array();
                $this->headers     = array();
                $this->parts       = array();
                $this->charsetlist = array('iso'  => 'us-ascii',
                                           'big5' => 'big5',
                                           'gb'   => 'gb2312');

                $this->charset     = 'us-ascii';

                if($headers == '') return TRUE;
                if(is_string($headers)) $headers = explode("\r\n", trim($headers));
                for($i=0; $i<count($headers); $i++){
                        if(is_array($headers[$i])) for($j=0; $j<count($headers[$i]); 
$j++) if($headers[$i][$j] != '') $this->headers[] = $headers[$i][$j];
                        if($headers[$i] != '') $this->headers[] = $headers[$i];
                }
        }

/***************************************
** Accessor function to set the body text.
** Body text is used if it's not an html
** mail being sent.
***************************************/

        function set_body($text = ''){
                if(is_string($text)){
                        $this->body = $text;
                        return TRUE;
                }
                return FALSE;
        }

/***************************************
** Accessor function to return the mime
** class variable. Purely for debug.
***************************************/

        function get_mime(){
                if(!isset($this->mime)) $this->mime = '';
                return $this->mime;
        }

/***************************************
** Function to set a header. Shouldn't
** really be necessary as you could use
** the constructor and send functions,
** it's here nonetheless. Takes any number
** of arguments, which can be either
** strings or arrays full of strings.
** this function is php4 only and will
** return false otherwise. Will return
** true upon finishing.
***************************************/

        function add_header(){
                if((int)phpversion() < 4) return FALSE;
                $args = func_get_args();
                for($i=0; $i<count($args); $i++){
                        if(is_array($args[$i])) for($j=0; $j<count($args[$i]); $j++) 
if($args[$i][$j] != '') $this->headers[] = $args[$i][$j];
                        if($args[$i] != '') $this->headers[] = $args[$i];
                }
                return TRUE;
        }

/***************************************
** Accessor function to set the content charset.
** Matt add 2000/10/19
***************************************/
        function set_charset($charset = '', $raw = FALSE){

                if($raw == TRUE){
                        $this->charset = $charset;
                        return TRUE;
                }

                if(is_string($charset)){
                        while(list($k,$v) = each($this->charsetlist)){
                                if($k == $charset){
                                        $this->charset = $v;
                                        return TRUE;
                                }
                        }
            }
            return FALSE;
        }

/***************************************
** Adds a html part to the mail.
** Also replaces image names with
** content-id's.
***************************************/
        function add_html($html, $text){
                $this->do_html   = 1;
                $this->html      = $html;
                $this->html_text = $text;
                if(is_array($this->html_images) AND count($this->html_images) > 0){
                        for($i=0; $i<count($this->html_images); $i++) $this->html = 
ereg_replace($this->html_images[$i]['name'], 'cid:'.$this->html_images[$i]['cid'], 
$this->html);
                }
        }

/***************************************
** Builds html part of email.
***************************************/
        function build_html($orig_boundary){
                $sec_boundary = '=_'.md5(uniqid(time()));
                $thr_boundary = '=_'.md5(uniqid(time()));

                if(count($this->html_images) == 0){
                        $this->multipart.= '--'.$orig_boundary."\r\n";
                        $this->multipart.= 'Content-Type: 
multipart/alternative;'.chr(13).chr(10).chr(9).'boundary="'.$sec_boundary."\"\r\n\r\n\r\n";

                        $this->multipart.= '--'.$sec_boundary."\r\n";
                        $this->multipart.= 'Content-Type: text/plain; 
charset="'.$this->charset.'"'."\r\n";
                        $this->multipart.= 'Content-Transfer-Encoding: 
base64'."\r\n\r\n";
                        $this->multipart.= 
chunk_split(base64_encode($this->html_text))."\r\n\r\n";

                        $this->multipart.= '--'.$sec_boundary."\r\n";
                        $this->multipart.= 'Content-Type: text/html; 
charset="'.$this->charset.'"'."\r\n";
                        $this->multipart.= 'Content-Transfer-Encoding: 
base64'."\r\n\r\n";
                        $this->multipart.= 
chunk_split(base64_encode($this->html))."\r\n\r\n";
                        $this->multipart.= '--'.$sec_boundary."--\r\n\r\n";
                }else{
                        $this->multipart.= '--'.$orig_boundary."\r\n";
                        $this->multipart.= 'Content-Type: 
multipart/related;'.chr(13).chr(10).chr(9).'boundary="'.$sec_boundary."\"\r\n\r\n\r\n";

                        $this->multipart.= '--'.$sec_boundary."\r\n";
                        $this->multipart.= 'Content-Type: 
multipart/alternative;'.chr(13).chr(10).chr(9).'boundary="'.$thr_boundary."\"\r\n\r\n\r\n";

                        $this->multipart.= '--'.$thr_boundary."\r\n";
                        $this->multipart.= 'Content-Type: text/plain; 
charset="'.$this->charset.'"'."\r\n";
                        $this->multipart.= 'Content-Transfer-Encoding: 
base64'."\r\n\r\n";
                        $this->multipart.= 
chunk_split(base64_encode($this->html_text))."\r\n\r\n";

                        $this->multipart.= '--'.$thr_boundary."\r\n";
                        $this->multipart.= 'Content-Type: text/html'."\r\n";
                        $this->multipart.= 'Content-Transfer-Encoding: 
base64'."\r\n\r\n";
                        $this->multipart.= 
chunk_split(base64_encode($this->html))."\r\n\r\n";
                        $this->multipart.= '--'.$thr_boundary."--\r\n\r\n";

                        for($i=0; $i<count($this->html_images); $i++){
                                $this->multipart.= '--'.$sec_boundary."\r\n";
                                $this->build_html_image($i);
                        }

                        $this->multipart.= "--".$sec_boundary."--\r\n\r\n";
                }
        }
/***************************************
** Adds an image to the list of embedded
** images.
***************************************/
        function add_html_image($file, $name = '', $c_type='application/octet-stream'){
                $this->html_images[] = array( 'body'   => $file,
                                              'name'   => $name,
                                              'c_type' => $c_type,
                                              'cid'    => md5(uniqid(time())) );
        }


/***************************************
** Adds a file to the list of attachments.
***************************************/
        function add_attachment($file, $name = '', $c_type='application/octet-stream'){
                $this->parts[] = array( 'body'   => $file,
                                        'name'   => $name,
                                        'c_type' => $c_type );
        }

/***************************************
** Builds an embedded image part of an
** html mail.
***************************************/
        function build_html_image($i){
                $this->multipart.= 'Content-Type: '.$this->html_images[$i]['c_type'];

                if($this->html_images[$i]['name'] != '') $this->multipart .= '; 
name="'.$this->html_images[$i]['name']."\"\r\n";
                else $this->multipart .= "\r\n";

                $this->multipart.= 'Content-Transfer-Encoding: base64'."\r\n";
                $this->multipart.= 'Content-ID: 
<'.$this->html_images[$i]['cid'].">\r\n\r\n";
                $this->multipart.= 
chunk_split(base64_encode($this->html_images[$i]['body']))."\r\n";
        }

/***************************************
** Builds a single part of a multipart
** message.
***************************************/
        function build_part($i){
                $message_part = '';
                $message_part.= 'Content-Type: '.$this->parts[$i]['c_type'];
                if($this->parts[$i]['name'] != '')
                        $message_part .= '; name="'.$this->parts[$i]['name']."\"\r\n";
                else
                        $message_part .= "\r\n";

                // Determine content encoding.
                if($this->parts[$i]['c_type'] == 'text/plain'){
                        $message_part.= 'Content-Transfer-Encoding: base64'."\r\n\r\n";
                        $message_part.= 
chunk_split(base64_encode($this->parts[$i]['body']))."\r\n";
                }elseif($this->parts[$i]['c_type'] == 'message/rfc822'){
                        $message_part.= 'Content-Transfer-Encoding: 7bit'."\r\n\r\n";
                        $message_part.= $this->parts[$i]['body']."\r\n";
                }else{
                        $message_part.= 'Content-Transfer-Encoding: base64'."\r\n";
                        $message_part.= 'Content-Disposition: attachment; 
filename="'.$this->parts[$i]['name']."\"\r\n\r\n";
                        $message_part.= 
chunk_split(base64_encode($this->parts[$i]['body']))."\r\n";
                }

                return $message_part;
        }

/***************************************
** Builds the multipart message from the
** list ($this->_parts).
***************************************/
        function build_message(){
                $boundary = '=_'.md5(uniqid(time()));

                $this->headers[] = 'MIME-Version: 1.0';
                $this->headers[] = 'Content-Type: 
multipart/mixed;'.chr(13).chr(10).chr(9).'boundary="'.$boundary.'"';
                $this->multipart = "This is a MIME encoded message.\r\n\r\n";

                if(isset($this->do_html) AND $this->do_html == 1) 
$this->build_html($boundary);
                if(isset($this->body) AND $this->body != '') $this->parts[] = 
array('body' => $this->body, 'name' => '', 'c_type' => 'text/plain');

                for($i=(count($this->parts)-1); $i>=0; $i--){
                        $this->multipart.= '--'.$boundary."\r\n".$this->build_part($i);
                }

                $this->mime = $this->multipart."--".$boundary."--\r\n";
        }

/***************************************
** Sends the mail.
***************************************/
        function send($to_name, $to_addr, $from_name, $from_addr, $subject = '', 
$headers = ''){

                if($to_name != '') $to = '"'.$to_name.'" <'.$to_addr.'>';
                else $to = $to_addr;

                if($from_name != '') $from = '"'.$from_name.'" <'.$from_addr.'>';
                else $from = $from_addr;

                if(is_string($headers)) $headers = explode("\r\n", trim($headers));
                for($i=0; $i<count($headers); $i++){
                        if(is_array($headers[$i])) for($j=0; $j<count($headers[$i]); 
$j++) if($headers[$i][$j] != '') $xtra_headers[] = $headers[$i][$j];
                        if($headers[$i] != '') $xtra_headers[] = $headers[$i];
                }
                if(!isset($xtra_headers)) $xtra_headers = array();

                mail($to, $subject, $this->mime, 'From: '.$from."\r\n".implode("\r\n", 
$this->headers)."\r\n".implode("\r\n", $xtra_headers));
        }

/***************************************
** Use this method to deliver using direct
** smtp connection. Relies upon Manuel Lemos'
** smtp mail delivery class available at:
** http://phpclasses.upperdesign.com
**
** void smtp_send( string *Name* of smtp object,
**                 string From address,
**                 array  To addresses,
**                 string Subject,
**                 array  Extra headers)
***************************************/
        function smtp_send($smtp_obj, $from_addr, $to_addr, $subject, $xtra_headers = 
''){
                global $$smtp_obj;
                $smtp_obj = $$smtp_obj;

                $headers   = $this->headers;
                $headers[] = 'From: '.$from_addr;
                $headers[] = 'Subject: '.$subject;
                if(is_array($xtra_headers)) for(reset($xtra_headers); list(,$header) = 
each($xtra_headers); ) $headers[] = $header;

                // the following: sendmessage(string from address, array to addresses, 
array headers, string body)
                $smtp_obj->sendmessage($from_addr, $to_addr, $headers, $this->mime);
        }

/***************************************
** Use this method to return the email
** in message/rfc822 format. Useful for
** adding an email to another email as
** an attachment. there's a commented
** out example in example.php.
**
** string get_rfc822(string To name,
**                   string To email,
**                   string From name,
**                   string From email,
**                   [string Subject,
**                    string Extra headers])
***************************************/
        function get_rfc822($to_name, $to_addr, $from_name, $from_addr, $subject = '', 
$headers = ''){

                // Make up the date header as according to RFC822
                $date = 'Date: '.date('D, d M y H:i:s');

                if($to_name != '') $to = 'To: "'.$to_name.'" <'.$to_addr.'>';
                else $to = $to_addr;

                if($from_name != '') $from = 'From: "'.$from_name.'" <'.$from_addr.'>';
                else $from = $from_addr;

                if(is_string($subject)) $subject = 'Subject: '.$subject;

                if(is_string($headers)) $headers = explode("\r\n", trim($headers));
                for($i=0; $i<count($headers); $i++){
                        if(is_array($headers[$i])) for($j=0; $j<count($headers[$i]); 
$j++) if($headers[$i][$j] != '') $xtra_headers[] = $headers[$i][$j];
                        if($headers[$i] != '') $xtra_headers[] = $headers[$i];
                }
                if(!isset($xtra_headers)) $xtra_headers = array();

                return 
$date."\r\n".$from."\r\n".$to."\r\n".$subject."\r\n".implode("\r\n", 
$this->headers)."\r\n".implode("\r\n", $xtra_headers)."\r\n\r\n".$this->mime;
        }


} // End of class.
?>

-- 
PHP General Mailing List (http://www.php.net/)
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]
To contact the list administrators, e-mail: [EMAIL PROTECTED]

Reply via email to