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;$i
$this->mailTo = implode($addressArray, ",")
true를 반환합니다. }
/************************************************
함수 setCC($inAddress) 복사하는 사람의 이메일 주소를 설정합니다
$inAddress 매개변수는 하나 이상의 이메일 주소, 이메일 주소 변수,
를 포함하는 문자열입니다.
여러 이메일 주소를 구분하려면 쉼표를 사용하세요. 기본 반환 값은 true입니다.
************************************************** * ************/
함수 setCC($inAddress){
//--explosion() 함수를 사용하여 ","를 기준으로 이메일 주소를 분할합니다.
$addressArray = 폭발( ",",$inAddress)
//--루프를 통해 이메일 주소의 유효성을 확인합니다
for($i=0;$i
$this->mailCC = implode($addressArray, ",")
true를 반환합니다. }
/***************************************************
setBCC($inAddress) 함수는 비밀 탄소 복사 주소를 설정합니다. $inAddress 매개변수에는 하나 이상의
이 포함됩니다.
이메일 주소 문자열, 이메일 주소 변수, 쉼표를 사용하여 여러 이메일 주소를 구분합니다. 기본 반환 값은
입니다.
사실
******************************************/
함수 setBCC($inAddress){
//--explosion() 함수를 사용하여 ","를 기준으로 이메일 주소를 분할합니다.
$addressArray = 폭발( ",",$inAddress)
//--루프를 통해 이메일 주소의 유효성을 확인합니다
for($i=0;$i
거짓을 반환
}
//--모든 법적 이메일 주소는 배열에 저장됩니다
$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 .= $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 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.