Heim > Backend-Entwicklung > PHP-Tutorial > PHP-Klasse zum Senden von E-Mails

PHP-Klasse zum Senden von E-Mails

WBOY
Freigeben: 2016-08-08 09:33:35
Original
1221 Leute haben es durchsucht

PHPs E-Mail-Sendeklasse

Die E-Mail-Versandklasse von PHP ist sehr leistungsfähig. Sie kann nicht nur E-Mails im HTML-Format senden, sondern auch Anhänge
Klasse E-Mail { 
//---Globale Variablen festlegen
var $mailTo = ""; // Empfänger
var $mailCC = ""; // CC
var $mailBCC = ""; // Geheimer CC
var $mailFrom = ""; // Absender
var $mailSubject = ""; // Betreff
var $mailText = "" // Der Textkörper des Briefes im Textformat
var $mailHTML = ""; // E-Mail-Text im HTML-Format
var $mailAttachments = ""; // Anhänge
/* Funktion setTo($inAddress): Die Adresse, die zum Verarbeiten von E-Mails verwendet wird. Parameter $inAddress
Um eine oder mehrere Zeichenfolgen und E-Mail-Adressvariablen einzuschließen, verwenden Sie Kommas, um mehrere E-Mail-Adressen zu trennen
Der Standardrückgabewert ist true
************************************************** * ********/ 
Funktion setTo($inAddress){
//--Verwenden Sie die Funktion explosion(), um die E-Mail-Adresse basierend auf ","
aufzuteilen $addressArray = explosion( ",",$inAddress); //--Überprüfen Sie die Gültigkeit der E-Mail-Adresse durch Schleife
for($i=0;$icheckEmail($addressArray[$i])==false) return false; }
//--Alle legalen E-Mail-Adressen werden im Array
gespeichert $this->mailTo = implode($addressArray, ","
return true; }
/************************************************
Funktion setCC($inAddress) Setzt die E-Mail-Adresse der Kopieperson
Der Parameter $inAddress ist eine Zeichenfolge, die eine oder mehrere E-Mail-Adressen, die E-Mail-Adressvariable
enthält Verwenden Sie Kommas, um mehrere E-Mail-Adressen zu trennen. Der Standardrückgabewert ist true
************************************************** * ************/
Funktion setCC($inAddress){
//--Verwenden Sie die Funktion explosion(), um die E-Mail-Adresse basierend auf ","
aufzuteilen $addressArray = explosion( ",",$inAddress); //--Überprüfen Sie die Gültigkeit der E-Mail-Adresse durch Schleife
for($i=0;$icheckEmail($addressArray[$i])==false) return false; }
//--Alle legalen E-Mail-Adressen werden im Array
gespeichert $this->mailCC = implode($addressArray, ","
return true; }
/*****************************************************
Die Funktion setBCC($inAddress) legt die geheime Kopieadresse fest. Der Parameter $inAddress enthält ein oder mehrere
Eine Zeichenfolge von E-Mail-Adressen, E-Mail-Adressvariable. Verwenden Sie Kommas, um mehrere E-Mail-Adressen zu trennen. Der Standardrückgabewert ist
wahr
******************************************/
Funktion setBCC($inAddress){
//--Verwenden Sie die Funktion explosion(), um die E-Mail-Adresse basierend auf ","
aufzuteilen $addressArray = explosion( ",",$inAddress); //--Überprüfen Sie die Gültigkeit der E-Mail-Adresse durch Schleife
for($i=0;$i { if($this->checkEmail($addressArray[$i])==false)
return false;
}
//--Alle legalen E-Mail-Adressen werden im Array
gespeichert $this->mailBCC = implode($addressArray, ","
return true;
}
/**************************************************** * *************
Funktion setFrom($inAddress): Setzt die Absenderadresse. Der Parameter $inAddress ist die enthaltene E-Mail
Der Standardrückgabewert der Adresszeichenfolge ist true
******************************************/
Funktion setFrom($inAddress){
if($this->checkEmail($inAddress)){
$this->mailFrom = $inAddress; return true;
} return false; }
/************************
Mit der Funktion setSubject($inSubject) wird der E-Mail-Betreffparameter $inSubject auf eine Zeichenfolge
gesetzt Der zurückgegebene Standardwert ist true
******************************************/
Funktion setSubject($inSubject){
if(strlen(trim($inSubject)) > 0){
$this->mailSubject = ereg_replace( "n", "",$inSubject); return true; }
return false; }
/***************************************************** ***** ***
Funktion setText($inText) Legt den E-Mail-Textparameter im Textformat fest. $inText ist standardmäßig auf den Textinhalt
eingestellt认返回值为true
****************************************/   
Funktion setText($inText){   
if(strlen(trim($inText)) > 0){   
$this->mailText = $inText;  
return true;  }  
return false;   
}   
/************************************
Funktion setHTML($inHTML) Setzt den E-Mail-Textparameter $inHTML im HTML-Format auf das HTML-Format
Der Standardrückgabewert ist true
************************************/   
Funktion setHTML($inHTML){   
if(strlen(trim($inHTML)) > 0){  
$this->mailHTML = $inHTML;   
return true;  }  
return false;  }  
/************************
Die Funktion setAttachments($inAttachments) legt den Parameter $inAttachments
für E-Mail-Anhänge fest Es handelt sich um eine Zeichenfolge, die ein Verzeichnis enthält. Sie kann auch mehrere durch Kommas getrennte Dateien enthalten. Der Standardrückgabewert ist true
******************************************/   
Funktion setAttachments($inAttachments){   
if(strlen(trim($inAttachments)) > 0){   
$this->mailAttachments = $inAttachments;   
return true;  }   
return false;  }  
/*********************************
Funktion checkEmail($inAddress): Wir haben diese Funktion bereits zuvor aufgerufen, hauptsächlich
Wird verwendet, um die Gültigkeit von E-Mail-Adressen zu überprüfen
*****************************************/  
Funktion checkEmail($inAddress){   
return (ereg( "^[^@ ] @([a-zA-Z0-9-] .) ([a-zA-Z0-9-]{2}|net|com|gov|mil|org|edu |int)$",$inAddress));
  }  
/*************************************************
Die Funktion loadTemplate($inFileLocation,$inHash,$inFormat) liest die temporäre Datei und
Ersetzen Sie den nutzlosen Informationsparameter $inFileLocation, um das Verzeichnis der Datei
zu finden $inHash zum Speichern temporärer Werte $inFormat zum Platzieren des E-Mail-Texts
************************************************** ************/   
Funktion loadTemplate($inFileLocation,$inHash,$inFormat){  
/*  比如邮件内有如下内容:  Sehr geehrter ~!UserName~,   
Ihre Adresse ist ~!UserAddress~  */   
//--其中“~!“为起始标志“~“为结束标志   
$templateDelim = "~";   
$templateNameStart = "!";   
//--找出这些地方并把他们替换掉   
$templateLineOut = "";  //--打开临时文件   
if($templateFile = fopen($inFileLocation, "r")){  
   while(!feof($templateFile)){   
$templateLine = fgets($templateFile,1000);    
$templateLineArray = explosion($templateDelim,$templateLine);   
for( $i=0; $i //--寻找起始位置   
if(strcspn($templateLineArray[$i],$templateNameStart)==0){   
//--替换相应的值   
$hashName = substr($templateLineArray[$i],1);   
//--替换相应的值     
$templateLineArray[$i] = ereg_replace($hashName,(string)$inHash[$hashName],$hashName);  
}  
}   
//--输出字符数组并叠加   
$templateLineOut .= implode($templateLineArray, "");  
}  //--关闭文件fclose($templateFile);   
//--设置主体格式(文本或html)   
if( strtoupper($inFormat)== "TEXT" )  
return($this->setText($templateLineOut));   
else if( strtoupper($inFormat)== "HTML" )
return($this->setHTML($templateLineOut));  
}  return false;
  }   
/*******************************************
Die Funktion getRandomBoundary($offset) gibt einen zufälligen Grenzwert
zurück Der Parameter $offset ist eine Ganzzahl – wird für Multi-Pipeline-Aufrufe verwendet und gibt eine md5()-codierte Zeichenfolge
zurück ******************************************/   
Funktion getRandomBoundary($offset = 0){   
//--随机数生成   
srand(time() $offset);   
//--返回 md5 编码的32位 字符长度的字串  
return ( "----".(md5(rand()))); }
/******************************************
Funktion: getContentType($inFileName) wird verwendet, um den Typ des Anhangs
zu bestimmen **********************************************/
Funktion getContentType($inFileName){
//--Pfad
entfernen $inFileName = Basisname($inFileName); //--Dateien ohne Erweiterung
entfernen if(strrchr($inFileName, ".") == false){
return „application/octet-stream“; }
//--Zonenerweiterung vorschlagen und ein Urteil fällen
$extension = strrchr($inFileName, "."); switch($extension){
case „.gif“: return „image/gif“; case „.gz“: return „application/x-gzip“; case „.htm“: return „text/html“; case „.html“: return „text/html“; case „.jpg“: return „image/jpeg“; case „.tar“: return „application/x-tar“; case „.txt“: return „text/plain“; case „.zip“: return „application/zip“; Standard: return „application/octet-stream“; }
return „application/octet-stream“; }
/***********************************************
Die Funktion formatTextHeader fügt den Textinhalt zum Textdatei-Header
hinzu ************************************************** * ***/
function formatTextHeader(){ $outTextHeader = ""; $outTextHeader .= "Content-Type: text/plain;
charset=us-asciin";
$outTextHeader .= "Content-Transfer-Encoding: 7bitnn"; $outTextHeader .= $this->mailText return $outTextHeader;
} /************************************************
Die Funktion formatHTMLHeader() fügt den HTML-Dateiheader zum E-Mail-Textinhalt
hinzu ******************************************/ 
Funktion formatHTMLHeader(){
$outHTMLHeader = ""; $outHTMLHeader .= "Inhaltstyp: text/html;
charset=us-asciin";
$outHTMLHeader .= "Content-Transfer-Encoding: 7bitnn"; $outHTMLHeader .= $this->mailHTML "n"; return $outHTMLHeader;
}
/************************************
Die Funktion formatAttachmentHeader($inFileLocation) identifiziert Anhänge in E-Mails
********************************/
Funktion formatAttachmentHeader($inFileLocation){
$outAttachmentHeader = ""; //--Verwenden Sie die obige Funktion getContentType($inFileLocation), um den Anhangstyp
abzurufen $contentType = $this->getContentType($inFileLocation); //--Wenn es sich bei dem Anhang um Text handelt, verwenden Sie die standardmäßige 7-stellige Kodierung
if(ereg( "text",$contentType)){ 
$outAttachmentHeader .= "Content-Type: ".$contentType. ";n"; $outAttachmentHeader .= ' name="'.basename($inFileLocation). '"' $outAttachmentHeader .= "Content-Transfer-Encoding: 7bitn"; $outAttachmentHeader .= "Content-Disposition: attachment;n"; $outAttachmentHeader .= ' filename="'.basename($inFileLocation). '"' $textFile = fopen($inFileLocation, "r"); while(!feof($textFile)){
$outAttachmentHeader .= fgets($textFile,1000); } 
//--Schließe die Datei fclose($textFile); $outAttachmentHeader .= "n"; }
//--Nicht-Textformate werden in 64 Bit
codiert else{ $outAttachmentHeader .= "Content-Type: ".$contentType ";n"; $outAttachmentHeader .= ' name="'.basename($inFileLocation). '"' $outAttachmentHeader .= "Content-Transfer-Encoding: base64n"; $outAttachmentHeader .= "Content-Disposition: attachment;n"; $outAttachmentHeader .= ' filename="'.basename($inFileLocation). '"' //--Rufen Sie den externen Befehl uuencode auf, um
zu kodieren exec( "uuencode -m $inFileLocation Nothing_out",$returnArray
for ($i = 1; $i<(count($returnArray)); $i ){
$outAttachmentHeader .= $returnArray[$i]. }
} return $outAttachmentHeader; }
/****************************
Die Funktion send() wird zum Versenden von E-Mails verwendet und der Rückgabewert ist wahr, wenn der Versand erfolgreich war
************************************/
Funktion send(){
//--Setzen Sie den E-Mail-Header auf leer
$mailHeader = "";
//--CC hinzufügen
if($this->mailCC != "")
$mailHeader .= "CC: ".$this->mailCC //--Geheime Durchschreibeperson hinzufügen
if($this->mailBCC != "")
$mailHeader .= "BCC: ".$this->mailBCC //--Absender hinzufügen
if($this->mailFrom != "")
$mailHeader .= "FROM: ".$this->mailFrom //---------------Mail-Format---------------- -- ----------
//--Textformat
if($this->mailText != "" && $this->mailHTML == "" && $this->mailAttachments == ""){
Rücksendemail($this->mailTo,$this->mailSubject,$this->mailText,$mailHeader); }
//--html oder Textformat
else if($this->mailText != "" && $this->mailHTML != "" && $this->mailAttachments == ""){
$bodyBoundary = $this->getRandomBoundary(); $textHeader = $this->formatTextHeader(); $htmlHeader = $this->formatHTMLHeader();
//--MIME-Version
festlegen $mailHeader .= "MIME-Version: 1.0n"; $mailHeader .= "Content-Type: multipart/alternative;n"; $mailHeader .= ' border="'.$bodyBoundary. '"'; $mailHeader .= "nnn"; //--E-Mail-Text und Grenzen hinzufügen
$mailHeader .= "--".$bodyBoundary. "n"; $mailHeader .= $textHeader; $mailHeader .= "--".$bodyBoundary. "n"; //--HTML-Tag hinzufügen
$mailHeader .= $htmlHeader; $mailHeader .= "n--".$bodyBoundary "--"; //--E-Mail senden
Rücksendemail($this->mailTo,$this->mailSubject, "",$mailHeader); }
//--Text plus HTML plus Anhänge
else if($this->mailText != "" && $this->mailHTML != "" && $this->mailAttachments != ""){
$attachmentBoundary = $this->getRandomBoundary(); $mailHeader .= "Content-Type: multipart/mixed;n"; $mailHeader .= ' border="'.$attachmentBoundary. '"' $mailHeader .= „Dies ist eine mehrteilige Nachricht im MIME-Format.n“; $mailHeader .= "--".$attachmentBoundary "n"; $bodyBoundary = $this->getRandomBoundary(1); $textHeader = $this->formatTextHeader(); $htmlHeader = $this->formatHTMLHeader();
$mailHeader .= "MIME-Version: 1.0n"; $mailHeader .= "Content-Type: multipart/alternative;n"; $mailHeader .= ' border="'.$bodyBoundary. '"'; $mailHeader .= "nnn"; $mailHeader .= "--".$bodyBoundary. "n"; $mailHeader .= $textHeader; $mailHeader .= "--".$bodyBoundary. "n"; $mailHeader .= $htmlHeader; $mailHeader .= "n--".$bodyBoundary "--"; //--Anhangswert abrufen
$attachmentArray = explosion( ",",$this->mailAttachments); //--Schleife basierend auf der Anzahl der Anhänge
for($i=0;$i //--Split $mailHeader .= "n--".$attachmentBoundary "n"; //--Anhangsinformationen
$mailHeader .= $this->formatAttachmentHeader($attachmentArray[$i]); } 
$mailHeader .= "--".$attachmentBoundary "--"; Rücksendemail($this->mailTo,$this->mailSubject, "",$mailHeader); } 
return false;
}
}
?>

Anwendung:
Fügen Sie „email.class“
ein
$mail->setTo("a@a.com"); //Empfänger
$mail-> setCC("b@b.com,c@c.com"); $mail-> setCC("d@b.com,e@c.com" //Geheimer CC
$mail->setFrom(“f@f.com”);//Sender
$mail->setSubject("Subject"); //Subject
$mail->setText("Textformat" ;//Das Sendetextformat kann auch eine Variable sein
$mail->setHTML("html format" ;//Das Senden des HTML-Formats kann auch eine Variable sein
$mail->setAttachments("c:a.jpg") ;//Um Anhänge hinzuzufügen, muss der Pfad angegeben werden
$mail->send(); //E-Mail senden

Das Obige stellt die E-Mail-Sendeklasse von PHP vor, einschließlich des Inhalts. Ich hoffe, dass es für Freunde hilfreich ist, die sich für PHP-Tutorials interessieren.

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage