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]