Heim >Backend-Entwicklung >PHP-Tutorial >PHP-Klasse zum Senden von E-Mails
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;$i
//--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;$i
//--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
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
$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.