> 백엔드 개발 > PHP 튜토리얼 > PHP 이메일 클래스 보내기

PHP 이메일 클래스 보내기

WBOY
풀어 주다: 2016-08-08 09:33:35
원래의
1229명이 탐색했습니다.

PHP의 이메일 보내기 강좌

PHP의 이메일 보내기 클래스는 HTML 형식의 이메일을 보낼 수 있을 뿐만 아니라 첨부 파일도 보낼 수 있습니다
. 수업 이메일 { 
//---전역 변수 설정
var $mailTo = "" // 수신자
var $mailCC = "" // CC
var $mailBCC = "" // 비밀 CC
var $mailFrom = "" // 보낸 사람
var $mailSubject = "" // 제목
var $mailText = ""; // 텍스트 형식의 편지 본문
var $mailHTML = ""; // HTML 형식의 이메일 본문
var $mailAttachments = "" // 첨부 파일
/* 함수 setTo($inAddress): 이메일 처리에 사용되는 주소 매개변수 $inAddress
하나 이상의 문자열과 이메일 주소 변수를 포함하려면 쉼표를 사용하여 여러 이메일 주소를 구분하세요.
기본 반환 값은 true입니다.
************************************************** * ********/ 
함수 setTo($inAddress){
//--explosion() 함수를 사용하여 ","를 기준으로 이메일 주소를 분할합니다.
$addressArray = 폭발( ",",$inAddress)
//--루프를 통해 이메일 주소의 유효성을 확인합니다
for($i=0;$icheckEmail($addressArray[$i])==false) return false; //--모든 법적 이메일 주소는 배열에 저장됩니다
$this->mailTo = implode($addressArray, ",")
true를 반환합니다. }
/************************************************
함수 setCC($inAddress) 복사하는 사람의 이메일 주소를 설정합니다
$inAddress 매개변수는 하나 이상의 이메일 주소, 이메일 주소 변수,
를 포함하는 문자열입니다. 여러 이메일 주소를 구분하려면 쉼표를 사용하세요. 기본 반환 값은 true입니다.
************************************************** * ************/
함수 setCC($inAddress){
//--explosion() 함수를 사용하여 ","를 기준으로 이메일 주소를 분할합니다.
$addressArray = 폭발( ",",$inAddress)
//--루프를 통해 이메일 주소의 유효성을 확인합니다
for($i=0;$icheckEmail($addressArray[$i])==false) return false; //--모든 법적 이메일 주소는 배열에 저장됩니다
$this->mailCC = implode($addressArray, ",")
true를 반환합니다. }
/***************************************************
setBCC($inAddress) 함수는 비밀 탄소 복사 주소를 설정합니다. $inAddress 매개변수에는 하나 이상의
이 포함됩니다. 이메일 주소 문자열, 이메일 주소 변수, 쉼표를 사용하여 여러 이메일 주소를 구분합니다. 기본 반환 값은
입니다. 사실
******************************************/ 
함수 setBCC($inAddress){
//--explosion() 함수를 사용하여 ","를 기준으로 이메일 주소를 분할합니다.
$addressArray = 폭발( ",",$inAddress)
//--루프를 통해 이메일 주소의 유효성을 확인합니다
for($i=0;$i { if($this->checkEmail($addressArray[$i])==false)
거짓을 반환
}
//--모든 법적 이메일 주소는 배열에 저장됩니다
$this->mailBCC = implode($addressArray, ",")

사실을 반환합니다. }
/**************************************************** * *************
함수 setFrom($inAddress): 보낸 사람 주소를 설정합니다. $inAddress 매개변수는 포함된 이메일입니다.
주소 문자열의 기본 반환 값은 true입니다.
****************************************/
함수 setFrom($inAddress){
if($this->checkEmail($inAddress)){
$this->mailFrom = $inAddress

사실을 반환합니다. } 거짓을 반환 }
/************************
setSubject($inSubject) 함수는 이메일 제목 매개변수 $inSubject를 문자열
으로 설정하는 데 사용됩니다. 기본 반환값은 true입니다.
*******************************************/
함수 setSubject($inSubject){
if(strlen(trim($inSubject)) > 0){
$this->mailSubject = ereg_replace( "n", "",$inSubject)
true를 반환합니다. }
거짓을 반환 }
/************************************************* ***** ***
함수 setText($inText) 이메일 본문 매개변수를 텍스트 형식으로 설정합니다. $inText의 기본값은 텍스트 콘텐츠입니다.
认返回值为사실
****************************************/   
함수 setText($inText){   
if(strlen(trim($inText)) > 0){   
$this->mailText = $inText;  
사실을 반환;  }  
거짓을 반환;   
}   
/************************************
함수 setHTML($inHTML) html 형식의 이메일 본문 매개변수 $inHTML을 html 형식으로 설정합니다.
기본 반환 값은 true입니다.
**************************************/   
함수 setHTML($inHTML){   
if(strlen(trim($inHTML)) > 0){  
$this->mailHTML = $inHTML;   
사실을 반환;  }  
거짓을 반환;  }  
/************************
함수 setAttachments($inAttachments)는 이메일 첨부 파일을 설정합니다. 매개 변수 $inAttachments
디렉터리를 포함하는 문자열입니다. 쉼표로 구분된 여러 파일을 포함할 수도 있습니다. 기본 반환 값은 true입니다. *******************************************/   
함수 setAttachments($inAttachments){   
if(strlen(trim($inAttachments)) > 0){   
$this->mailAttachments = $in첨부 파일;   
사실을 반환;  }   
거짓을 반환;  }  
/*******************************
함수 checkEmail($inAddress): 이전에 이 함수를 이미 호출했습니다. 주로
이메일 주소의 유효성을 확인하는 데 사용됩니다
*****************************************/  
함수 checkEmail($inAddress){   
return (ereg( "^[^@ ]+@([a-zA-Z0-9-]+.)+([a-zA-Z0-9-]{2}|net|com|gov|mil| org|edu|int)$",$inAddress));
  }  
/*************************************************
loadTemplate($inFileLocation,$inHash,$inFormat) 함수는 임시 파일을 읽고

파일의 디렉터리를 찾기 위해 쓸모 없는 정보 매개변수 $inFileLocation을 바꾸세요. 임시 값을 저장하기 위한 $inHash 이메일 본문 배치를 위한 $inFormat
************************************************** * ***********/   
함수 loadTemplate($inFileLocation,$inHash,$inFormat){  
/*  比如邮件内有如下内容:  ~!UserName~님께,   
귀하의 주소는 ~!UserAddress~입니다.  */   
//--其中”~!”为起始标志”~”为结束标志   
$templateDelim = "~";   
$templateNameStart = "!";   
//--추출这些地方并把他们替换掉   
$templateLineOut = "";  //--打开临时文件   
if($templateFile = fopen($inFileLocation, "r")){  
   while(!feof($templateFile)){   
$templateLine = fgets($templateFile,1000);    
$templateLineArray = 폭발($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));  
}  거짓을 반환합니다.
  }   
/*****************************************
getRandomBoundary($offset) 함수는 임의의 경계 값을 반환합니다.
$offset 매개변수는 정수입니다. 다중 파이프라인 호출에 사용되며 md5()로 인코딩된 문자열을 반환합니다.
****************************************/   
함수 getRandomBoundary($offset = 0){   
//--随机数生成   
srand(time()+$offset);   
//--返回 md5 编码 的 32位 字符长titude 字串  
return ( "----".(md5(rand()))) }
/******************************************
기능: getContentType($inFileName)은 첨부 파일 유형을 결정하는 데 사용됩니다.
**********************************************/
함수 getContentType($inFileName){
//--경로 제거
$inFileName = 기본 이름($inFileName)
//--확장자가 없는 파일 제거
if(strrchr($inFileName, ".") == false){
"응용프로그램/옥텟-스트림"을 반환합니다
}
//--존 확장 제안 및 판단
$extension = strrchr($inFileName, ".")
스위치($확장자){
케이스 ".gif": "이미지/gif" 반환
케이스 ".gz": "application/x-gzip" 반환
케이스 ".htm": "text/html" 반환
케이스 ".html": "텍스트/html" 반환
케이스 ".jpg": "이미지/jpeg" 반환
케이스 ".tar": "application/x-tar" 반환
케이스 ".txt": "텍스트/일반" 반환
케이스 ".zip": "application/zip" 반환
기본값: "application/octet-stream"을 반환합니다.
}
"응용프로그램/옥텟-스트림"을 반환합니다
}
/***********************************************
formatTextHeader 함수는 텍스트 파일 헤더
에 텍스트 내용을 추가합니다. ************************************************** * ***/
함수 formatTextHeader(){ $outTextHeader = ""
$outTextHeader .= "콘텐츠 유형: 텍스트/일반;
charset=us-asciin";
$outTextHeader .= "콘텐츠 전송 인코딩: 7bitnn"
$outTextHeader .= $this->mailText
$outTextHeader를 반환합니다.
} /************************************************
formatHTMLHeader() 함수는 html 파일 헤더를 이메일 본문 콘텐츠에 추가합니다.
******************************************/ 
함수 형식HTMLHeader(){
$outHTMLHeader = ""
$outHTMLHeader .= "콘텐츠 유형: 텍스트/html;
charset=us-asciin";
$outHTMLHeader .= "콘텐츠 전송 인코딩: 7bitnn"
$outHTMLHeader .= $this->mailHTML
$outHTMLHeader 반환
}
/************************************
함수 formatAttachmentHeader($inFileLocation)는 이메일의 첨부 파일을 식별합니다.
********************************/
함수 형식AttachmentHeader($inFileLocation){
$outAttachmentHeader = ""
//--위 함수 getContentType($inFileLocation)을 사용하여 첨부 파일 유형을 가져옵니다.
$contentType = $this->getContentType($inFileLocation)
//--첨부파일이 텍스트인 경우 표준 7자리 인코딩을 사용하세요.
if(ereg( "text",$contentType)){ 
$outAttachmentHeader .= "콘텐츠 유형: ".$contentType."
$outAttachmentHeader .= ' name="'.basename($inFileLocation). '"'.
$outAttachmentHeader .= "콘텐츠 전송 인코딩: 7bitn"
$outAttachmentHeader .= "콘텐츠 처리: 첨부 파일;n"
$outAttachmentHeader .= ' filename="'.basename($inFileLocation). '"'. "nn"
$textFile = fopen($inFileLocation, "r")
while(!feof($textFile)){
$outAttachmentHeader .= fgets($textFile,1000)

//--파일을 닫습니다. fclose($textFile)
$outAttachmentHeader .= "n"
}
//--텍스트가 아닌 형식은 64비트로 인코딩됩니다.
else{ $outAttachmentHeader .= "콘텐츠 유형: ".$contentType.
$outAttachmentHeader .= ' name="'.basename($inFileLocation). '"'.
$outAttachmentHeader .= "콘텐츠 전송 인코딩: base64n"
$outAttachmentHeader .= "콘텐츠 처리: 첨부 파일;n"
$outAttachmentHeader .= ' filename="'.basename($inFileLocation). '"'. "nn"
//--인코딩하려면 uuencode 외부 명령을 호출하세요.
exec("uuencode -m $inFileLocation Nothing_out",$returnArray)
for ($i = 1; $i<(count($returnArray)); $i++){
$outAttachmentHeader.= $returnArray[$i]
}
} $outAttachmentHeader를 반환합니다.
}
/******************************
send() 함수는 이메일을 보내는 데 사용되며, 성공적으로 전송되면 반환 값은 true입니다
**************************************/
함수 보내기(){
//--이메일 헤더를 비우도록 설정
$mailHeader = ""
//--CC 추가
if($this->mailCC != "")
$mailHeader .= "CC: ".$this->mailCC.
//--비밀 사본 사람 추가
if($this->mailBCC != "")
$mailHeader .= "BCC: ".$this->mailBCC
//--발신자 추가
if($this->mailFrom != "")
$mailHeader .= "FROM: ".$this->mailFrom "n"; //------------------메일 형식---------------- -- ----------
//--텍스트 형식
if($this->mailText != "" && $this->mailHTML == "" && $this->mailAttachments == ""){
return mail($this->mailTo,$this->mailSubject,$this->mailText,$mailHeader); }
//--html 또는 텍스트 형식
else if($this->mailText != "" && $this->mailHTML != "" && $this->mailAttachments == ""){
$bodyBoundary = $this->getRandomBoundary()
$textHeader = $this->formatTextHeader()
$htmlHeader = $this->formatHTMLHeader()
//--MIME 버전 설정
$mailHeader .= "MIME 버전: 1.0n"
$mailHeader .= "콘텐츠 유형: 다중 부분/대체;n"
$mailHeader .= 'boundary="'.$bodyBoundary.'"'
$mailHeader .= "nnn"
//--이메일 본문 및 경계 추가
$mailHeader .= "--".$bodyBoundary
$mailHeader .= $textHeader
$mailHeader .= "--".$bodyBoundary
//--html 태그 추가
$mailHeader .= $html헤더
$mailHeader .= "n--".$bodyBoundary.
//--이메일 보내기
return mail($this->mailTo,$this->mailSubject, "",$mailHeader
}
//--텍스트, HTML, 첨부 파일
else if($this->mailText != "" && $this->mailHTML != "" && $this->mailAttachments != ""){
$attachmentBoundary = $this->getRandomBoundary()
$mailHeader .= "콘텐츠 유형: 다중 부분/혼합;n"
$mailHeader .= 'boundary="'.$attachmentBoundary.'"'
$mailHeader .= "이것은 MIME 형식의 여러 부분으로 구성된 메시지입니다.n"; $mailHeader .= "--".$attachmentBoundary.
$bodyBoundary = $this->getRandomBoundary(1)
$textHeader = $this->formatTextHeader()
$htmlHeader = $this->formatHTMLHeader()
$mailHeader .= "MIME 버전: 1.0n"
$mailHeader .= "콘텐츠 유형: 다중 부분/대체;n"
$mailHeader .= 'boundary="'.$bodyBoundary.'"'
$mailHeader .= "nnn"
$mailHeader .= "--".$bodyBoundary
$mailHeader .= $textHeader
$mailHeader .= "--".$bodyBoundary
$mailHeader .= $html헤더
$mailHeader .= "n--".$bodyBoundary.
//--첨부파일 값 가져오기
$attachmentArray = 폭발( ",",$this->mailAttachments); //--첨부 파일 수를 기준으로 반복
for($i=0;$i //--$mailHeader 분할 .= "n--".$attachmentBoundary
//--첨부정보
$mailHeader .= $this->formatAttachmentHeader($attachmentArray[$i])

$mailHeader .= "--".$attachmentBoundary.
return mail($this->mailTo,$this->mailSubject, "",$mailHeader

거짓을 반환
}
}
?>

사용방법:

"email.class" 포함

$mail->setTo("a@a.com") //수신자
$mail-> setCC("b@b.com,c@c.com") //CC
$mail-> setCC("d@b.com,e@c.com") //비밀 CC
$mail->setFrom(“f@f.com”);//발신자
$mail->setSubject("제목") //제목
$mail->setText("텍스트 형식") ;//보내는 텍스트 형식도 변수일 수 있습니다
$mail->setHTML("html 형식") ;//html 형식 전송도 변수일 수 있습니다
$mail->setAttachments("c:a.jpg") ;//첨부파일을 추가하려면 경로를 지정해야 합니다
$mail->send() //이메일 보내기

위의 내용을 포함하여 PHP의 이메일 보내기 클래스를 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿