Modif pour grer si il n'y a pas de fichier joint
This commit is contained in:
parent
ca670b0a7d
commit
c49dc7978f
@ -19,77 +19,92 @@ to chunk_split
|
||||
/* Note: if you don't have base64_encode on your sytem it will not work */
|
||||
|
||||
// simple class that encapsulates mail() with addition of mime file attachment.
|
||||
class CMailFile {
|
||||
var $subject;
|
||||
var $addr_to;
|
||||
var $text_body;
|
||||
var $text_encoded;
|
||||
var $mime_headers;
|
||||
var $mime_boundary = "--==================_846811060==_";
|
||||
var $smtp_headers;
|
||||
|
||||
function CMailFile($subject,$to,$from,$msg,$filename,$mimetype = "application/octet-stream", $mime_filename = false) {
|
||||
$this->subject = $subject;
|
||||
$this->addr_to = $to;
|
||||
$this->smtp_headers = $this->write_smtpheaders($from);
|
||||
$this->text_body = $this->write_body($msg);
|
||||
$this->text_encoded = $this->attach_file($filename,$mimetype,$mime_filename);
|
||||
$this->mime_headers = $this->write_mimeheaders($filename, $mime_filename);
|
||||
}
|
||||
class CMailFile
|
||||
{
|
||||
var $subject;
|
||||
var $addr_to;
|
||||
var $text_body;
|
||||
var $text_encoded;
|
||||
var $mime_headers;
|
||||
var $mime_boundary = "--==================_846811060==_";
|
||||
var $smtp_headers;
|
||||
|
||||
function CMailFile($subject,$to,$from,$msg,$filename,$mimetype = "application/octet-stream", $mime_filename = false)
|
||||
{
|
||||
$this->subject = $subject;
|
||||
$this->addr_to = $to;
|
||||
$this->smtp_headers = $this->write_smtpheaders($from);
|
||||
$this->text_body = $this->write_body($msg, $filename);
|
||||
|
||||
function attach_file($filename,$mimetype,$mime_filename) {
|
||||
$encoded = $this->encode_file($filename);
|
||||
if ($mime_filename) $filename = $mime_filename;
|
||||
$out = "--" . $this->mime_boundary . "\n";
|
||||
$out = $out . "Content-type: " . $mimetype . "; name=\"$filename\";\n";
|
||||
$out = $out . "Content-Transfer-Encoding: base64\n";
|
||||
$out = $out . "Content-disposition: attachment; filename=\"$filename\"\n\n";
|
||||
$out = $out . $encoded . "\n";
|
||||
$out = $out . "--" . $this->mime_boundary . "--" . "\n";
|
||||
return $out;
|
||||
// added -- to notify email client attachment is done
|
||||
}
|
||||
if (strlen($filename))
|
||||
{
|
||||
$this->text_encoded = $this->attach_file($filename,$mimetype,$mime_filename);
|
||||
$this->mime_headers = $this->write_mimeheaders($filename, $mime_filename);
|
||||
}
|
||||
}
|
||||
|
||||
function encode_file($sourcefile) {
|
||||
if (is_readable($sourcefile)) {
|
||||
$fd = fopen($sourcefile, "r");
|
||||
$contents = fread($fd, filesize($sourcefile));
|
||||
$encoded = my_chunk_split(base64_encode($contents));
|
||||
fclose($fd);
|
||||
}
|
||||
return $encoded;
|
||||
}
|
||||
function attach_file($filename,$mimetype,$mime_filename)
|
||||
{
|
||||
$encoded = $this->encode_file($filename);
|
||||
if ($mime_filename) $filename = $mime_filename;
|
||||
$out = "--" . $this->mime_boundary . "\n";
|
||||
$out = $out . "Content-type: " . $mimetype . "; name=\"$filename\";\n";
|
||||
$out = $out . "Content-Transfer-Encoding: base64\n";
|
||||
$out = $out . "Content-disposition: attachment; filename=\"$filename\"\n\n";
|
||||
$out = $out . $encoded . "\n";
|
||||
$out = $out . "--" . $this->mime_boundary . "--" . "\n";
|
||||
return $out;
|
||||
// added -- to notify email client attachment is done
|
||||
}
|
||||
|
||||
function sendfile() {
|
||||
$headers = $this->smtp_headers . $this->mime_headers;
|
||||
$message = $this->text_body . $this->text_encoded;
|
||||
return mail($this->addr_to,$this->subject,$message,$headers);
|
||||
}
|
||||
|
||||
function write_body($msgtext) {
|
||||
$out = "--" . $this->mime_boundary . "\n";
|
||||
$out = $out . "Content-Type: text/plain; charset=\"us-ascii\"\n\n";
|
||||
$out = $out . $msgtext . "\n";
|
||||
return $out;
|
||||
}
|
||||
|
||||
function write_mimeheaders($filename, $mime_filename) {
|
||||
if ($mime_filename) $filename = $mime_filename;
|
||||
$out = "MIME-version: 1.0\n";
|
||||
$out = $out . "Content-type: multipart/mixed; ";
|
||||
$out = $out . "boundary=\"$this->mime_boundary\"\n";
|
||||
$out = $out . "Content-transfer-encoding: 7BIT\n";
|
||||
$out = $out . "X-attachments: $filename;\n\n";
|
||||
return $out;
|
||||
}
|
||||
|
||||
function write_smtpheaders($addr_from) {
|
||||
$out = "From: $addr_from\n";
|
||||
$out = $out . "Reply-To: $addr_from\n";
|
||||
$out = $out . "X-Mailer: PHP3\n";
|
||||
$out = $out . "X-Sender: $addr_from\n";
|
||||
return $out;
|
||||
}
|
||||
function encode_file($sourcefile)
|
||||
{
|
||||
if (is_readable($sourcefile))
|
||||
{
|
||||
$fd = fopen($sourcefile, "r");
|
||||
$contents = fread($fd, filesize($sourcefile));
|
||||
$encoded = my_chunk_split(base64_encode($contents));
|
||||
fclose($fd);
|
||||
}
|
||||
return $encoded;
|
||||
}
|
||||
|
||||
function sendfile()
|
||||
{
|
||||
$headers = $this->smtp_headers . $this->mime_headers;
|
||||
$message = $this->text_body . $this->text_encoded;
|
||||
return mail($this->addr_to,$this->subject,$message,$headers);
|
||||
}
|
||||
|
||||
function write_body($msgtext, $filename)
|
||||
{
|
||||
if (strlen($filename))
|
||||
{
|
||||
$out = "--" . $this->mime_boundary . "\n";
|
||||
$out = $out . "Content-Type: text/plain; charset=\"us-ascii\"\n\n";
|
||||
}
|
||||
$out = $out . $msgtext . "\n";
|
||||
return $out;
|
||||
}
|
||||
|
||||
function write_mimeheaders($filename, $mime_filename) {
|
||||
if ($mime_filename) $filename = $mime_filename;
|
||||
$out = "MIME-version: 1.0\n";
|
||||
$out = $out . "Content-type: multipart/mixed; ";
|
||||
$out = $out . "boundary=\"$this->mime_boundary\"\n";
|
||||
$out = $out . "Content-transfer-encoding: 7BIT\n";
|
||||
$out = $out . "X-attachments: $filename;\n\n";
|
||||
return $out;
|
||||
}
|
||||
|
||||
function write_smtpheaders($addr_from)
|
||||
{
|
||||
$out = "From: $addr_from\n";
|
||||
$out = $out . "Reply-To: $addr_from\n";
|
||||
$out = $out . "X-Mailer: PHP3\n";
|
||||
$out = $out . "X-Sender: $addr_from\n";
|
||||
return $out;
|
||||
}
|
||||
}
|
||||
|
||||
// usage - mimetype example "image/gif"
|
||||
|
||||
Loading…
Reference in New Issue
Block a user