ホームページ php教程 php手册 PHP クラス 電子メールを送信するためのフル機能のクラス

PHP クラス 電子メールを送信するためのフル機能のクラス

Jun 13, 2016 pm 12:41 PM
class email php コード 全体的な状況 送信 変数 コピー 親切 設定 郵便

コードをコピー コードは次のとおりです:


class Email {
//--- グローバル変数を設定します
var $mailTo = "" // 受信者
var $mailCC = " "; // Cc
var $mailBCC = ""; // 秘密 Cc
var $mailFrom = ""; // 送信者
var $mailSubject = ""; // 件名
var $mailText = ""; // テキスト形式のレター本文
var $mailHTML = "" // HTML 形式のレター本文
var $mailAttachments = ""; // 添付ファイル
; * 関数 setTo($inAddress): 電子メールの処理に使用されるアドレス パラメーター $inAddress
には、1 つ以上の文字列、電子メール アドレス変数が含まれます。複数の電子メール アドレスを区切るにはカンマを使用します
デフォルトの戻り値は true
* *********************************************** *** *******/
function setTo($inAddress){
//--explode() 関数を使用して、「,」に従って電子メール アドレスを分割します。
$addressArray =explode( " ,",$inAddress);
//-- ループを通じて電子メール アドレスの有効性をチェックします
for($i=0;$icheckEmail($addressArray[$i])==false) return false; }
//--すべての正当な電子メール アドレスは配列
$this->mailTo = implode( $addressArray , ",");
return true; }
/************************************************
関数setCC($inAddress) は、カーボン コピー者の電子メール アドレスを設定します。
パラメータ $inAddress は、1 つ以上の電子メール アドレス、電子メール アドレス変数を含む文字列です。
複数の電子メール アドレスを区切るには、カンマを使用します。デフォルトの戻り値。値は true
******************************************** **** ****************/
function setCC($inAddress){
//--「」に従ってexplode()関数を使用します。 ," メール アドレスを分割します
$addressArray =explode( ",",$inAddress);
//--ループを通じてメール アドレスの有効性を確認します
for($i=0; $ icheckEmail($addressArray[$i])==false) return false }
//--すべての正当な電子メール アドレスが保存されます。配列
$this->mailCC = implode($addressArray, ",");
return true; }
/***************************************************
関数 setBCC($inAddress) は、シークレット カーボン コピー アドレス パラメーター $inAddress を、1 つ以上の
電子メール アドレスを含む文字列 (電子メール アドレス変数) に設定します。複数の電子メール アドレスを区切るにはカンマを使用します。デフォルトの戻り値は
本当の
*******************************************/
function setBCC($inAddress) {
//--explode() 関数を使用して、「,"
$addressArray =explode( ",",$inAddress) に従ってメール アドレスを分割します。
//--メール アドレスを分割します。ループによって合法性をチェックします
for($i=0;$i{ if($this->checkEmail($addressArray[$i])==false )
return false;
}
//--すべての有効な電子メール アドレスは配列
$this->mailBCC = implode($addressArray, ","); に保存されます。 true を返す;
}
/*************************************************** * *************
関数 setFrom($inAddress): 送信者アドレス パラメーター $inAddress を電子メール
アドレスを含む文字列に設定します。デフォルトの戻り値は true <🎜 です。 >* *************************************/
function setFrom($inAddress){
if($this->checkEmail($inAddress)){
$this ->mailFrom = $inAddress;
return true;
} return false; }
/************************
関数 setSubject($inSubject) は、電子メールの件名パラメーター $inSubject を文字列に設定するために使用されます。
デフォルトの戻り値は true
*******************************************/
function setSubject($inSubject){
if(トリム($inSubject)) > 0){
$this->mailSubject = ereg_replace( "n", "",$inSubject);
return false; >/*************************************************** *
関数 setText($inText) は、メール本文パラメータをテキスト形式で設定します。$inText は、デフォルトの戻り値です。
************* ********** **********************/
function setText($inText){
if(strlen(trim($inText)) > 0){
$this->mailText = $inText;
true を返す; }
false を返す;
/****************************************
関数 setHTML($inHTML) は電子メール本文パラメータを設定しますHTML 形式の $inHTML HTML 形式です。
デフォルトの戻り値は true
*************************** **************/
function setHTML($inHTML){
if(strlen($inHTML) ) > 0){
$this->mailHTML = $inHTML;
return false; }
/************************
関数 setAttachments($inAttachments) は電子メールの添付ファイル パラメータを設定します $inAttachments
はディレクトリを含む文字列です。複数のファイルを含めることもできます。デフォルトの戻り値は true
****************************** です。 ****** ********/
関数$inAttachments){
if(strlen(trim($inAttachments)) > 0){
$this->mailAttachments = $inAttachments;
return false; 🎜>/**********************************
関数 checkEmail($inAddress): この関数は以前に呼び出したことがあります。
メールアドレスの正当性をチェックするために使用されます
********************************** ** ***/
function 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)は、一時ファイルを読み取り、不要な情報を置き換えます。
$inHashは、ファイルのディレクトリを見つけるために使用されます。 $inFormat はメール本文を配置するために使用されます
*********************************** ************* ***********/
functionloadTemplate($inFileLocation,$inHash, $inFormat){
/* たとえば、メールには次の内容が含まれています: Dear ~!UserName~,
あなたのアドレスは ~!UserAddress~ */
//--"~!"開始マーク "~" は終了マークです
$templateDelim = "~";
$templateNameStart = "!"
//--これらの場所を検索して置換します
$templateLineOut = "" ; //-- 一時ファイルを開きます
if($templateFile = fopen($inFileLocation, "r")){
while(!feof($templateFile)){
$templateLine = fgets($templateFile ,1000);
$templateLineArray =explode($templateDelim,$templateLine);
for( $i=0; $i//--Find開始位置
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)); if( strtoupper($inFormat)== "HTML" )
return($this->setHTML($templateLineOut))
} return
}
/******************************************
関数 getRandomBoundary($offset) は戻りますランダムな境界値
パラメータ $offset は整数です – 複数のパイプラインの呼び出しは md5() でエンコードされた文字列を返します
******************** **** ********************* */
function getRandomBoundary($offset = 0){
//--乱数生成
srand(time() $offset);
//--md5 でエンコードされた 32 ビット文字を返すlength String
return ( "----".(md5(rand()))); }
/**********************************************
関数: getContentType($ inFileName) は、添付ファイルの種類を決定するために使用されます
************************************* ***** *****/
function getContentType($inFileName){
/ /--パスを削除します
$inFileName =basename($inFileName);
//--拡張子なしでファイルを削除します
if(strrchr($inFileName, ".") == false){
return "application/octet-stream";
}
//--拡張子名を指定して判断します
$extension = strrchr($inFileName, ".");拡張子){
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";
デフォルト: return "application/octet-stream";
}
return "application/octet-stream";
}
/**************************************************
関数 formatTextHeader は、テキストコンテンツとテキストファイルヘッダーを配置します
************************************ ****** **************/
function formatTextHeader(){ $outTextHeader = ""
$outTextHeader 。 = "コンテンツ タイプ: text/plain;
charset=us-asciin";
$outTextHeader .= "コンテンツ転送エンコーディング: 7bitnn"; . "n";
return $outTextHeader; /**************************************************
関数 formatHTMLHeader() は、HTML ファイルのヘッダーをメール本文のコンテンツに追加します
******************************** ** ********/
function formatHTMLHeader = ""
$outHTMLHeader; -タイプ: text/html;
charset=us-asciin";
$outHTMLHeader .= "Content-Transfer-Encoding: 7bitnn";
$outHTMLHeader .= $this->mailHTML. " n ";
return $outHTMLHeader;
}
/****************************************
関数 formatAttachmentHeader($inFileLocation) は、次の添付ファイルを識別します。メール
************************************/
function formatAttachmentHeader($inFileLocation){
$outAttachmentHeader = "";
//- -上記の関数 getContentType($inFileLocation) を使用して添付ファイルの種類を取得します。
$contentType = $this->getContentType($inFileLocation)
//--添付ファイルがテキスト タイプの場合は、標準の 7 ビットを使用します。エンコーディング
if(ereg( "text",$contentType)){
$outAttachmentHeader .= "Content-Type: ".$contentType. ";n";
$outAttachmentHeader .= ' name=" ' .basename($inFileLocation). '"'. "n";
$outAttachmentHeader .= "Content-Transfer-Encoding: 7bitn";
$outAttachmentHeader .= "Content-Disposition:attachment;n";
$outAttachmentHeader .= ' filename="'.basename($inFileLocation). '"'. "nn";
$textFile = fopen($inFileLocation, "r"); ( $textFile)){
$outAttachmentHeader .= fgets($textFile,1000);
//--ファイルを閉じます fclose($textFile);
$outAttachmentHeader .= "n";
}
//--非テキスト形式は 64 ビットでエンコードされます
else { $outAttachmentHeader .= "Content-Type: ".$contentType. ";n";
$outAttachmentHeader .= ' name="'.basename($inFileLocation). '"'; > $outAttachmentHeader .= "Content-Transfer-Encoding:base64n";
$outAttachmentHeader .= "Content-Disposition:attachment;n";
$outAttachmentHeader .= ' filename="'.basename($inFileLocation) . '"'. "nn";
//-- エンコード用の外部コマンド uuencode を呼び出します
exec( "uuencode -m $inFileLocation nothing_out",$returnArray);
for ($i = 1) ; $ i<(count($returnArray)); $i ){
$outAttachmentHeader .= $returnArray[$i];
}
}
/**********************************
関数 send() はメールの送信に使用され、戻り値は true です正常に送信された場合
* *************************************/
function send(){
//--メールヘッダーを空に設定します
$mailHeader = ""
//-- カーボンを追加します受信者をコピー
if($this->mailCC != "")
$mailHeader .= "CC: ".$this->mailCC.
//--シークレットを追加カーボンコピーの人
if($this->mailBCC != "")
$mailHeader .= "BCC: ".$this->mailBCC.
//--Add送信者
if($this->mailFrom != "")
$mailHeader .= "FROM: ".$this->mailFrom.
; - ----------メール形式--------------- ---
//--テキスト形式
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 .= "Content-Type: multipart/alternative;n"
$mailHeader .= 'boundary="'.$bodyBoundary. '"'; >$mailHeader .= "nnn";
//--メール本文と境界を追加します
$mailHeader .= "-".$bodyBoundary.
$mailHeader .= $textHeader;
$mailHeader .= "--".$bodyBoundary. "n";
//--HTML タグを追加します
$mailHeader .= $htmlHeader; ".$bodyBoundary. "--";
//--メールを送信
return mail($this->mailTo,$this->mailSubject, "",$mailHeader);
}
//--テキストと HTML と添付ファイル
else if($this->mailText != "" && $this->mailHTML != "" && $this->mailAttachments != "" ){
$attachmentBoundary = $this->getRandomBoundary();
$mailHeader .= "Content-Type: multipart/mixed;n";
$mailHeader .= 'boundary="'.$ attachmentBoundary.'"'."nn";
$mailHeader .= "これは MIME 形式のマルチパート メッセージです。n";
$mailHeader .= "--".$attachmentBoundary. "n" ;
$bodyBoundary = $this->getRandomBoundary(1);
$textHeader = $this->formatTextHeader();
$htmlHeader = $this->formatHTMLHeader(); $mailHeader .= "MIME バージョン: 1.0n";
$mailHeader .= "Content-Type: multipart/alternative;n";
$mailHeader .= 'boundary="'.$bodyBoundary. '" ';
$mailHeader .= "nnn";
$mailHeader .= "-".$bodyBoundary.= " --".$bodyBoundary. "n";
$mailHeader .= $htmlHeader;
$mailHeader .= "n--".$bodyBoundary. "--";
//--Get添付ファイルの値
$attachmentArray =explode( ",",$this->mailAttachments);
//--添付ファイルの数に応じてループします
for($i=0;$i//--$mailHeader を分割します。= "n--".$attachmentBoundary."n";
//--添付ファイル情報
$mailHeader .= $this->formatAttachmentHeader($attachmentArray[$i]);
}
$mailHeader .= "--".$attachmentBoundary.
return mail($this-> mailTo,$this->mailSubject, "",$mailHeader);
}
return false;
}
}
?>



使用法:



コードをコピーします


コードは次のとおりです:

<「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") );//Sender
$mail->setSubject("Subject"); //Subject
$mail->setText("Text Format");//テキスト形式で送信することも可能ですvariable
$mail->setHTML("html format");//送信する HTML 形式を変数にすることもできます
$mail->setAttachments("c:a.jpg");//添付ファイルを追加します、パスを指定する必要があります
$mail->send() //メールを送信します
?>


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP データベースの操作 CakePHP データベースの操作 Sep 10, 2024 pm 05:25 PM

CakePHP でデータベースを操作するのは非常に簡単です。この章では、CRUD (作成、読み取り、更新、削除) 操作について理解します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

See all articles