ホームページ バックエンド開発 PHPチュートリアル 詳細な手順を記載した電子メールを送信するためのフル機能の PHP コード_PHP チュートリアル

詳細な手順を記載した電子メールを送信するためのフル機能の PHP コード_PHP チュートリアル

Jul 21, 2016 pm 03:51 PM
php VA コード 全体的な状況 送信 変数 親切 設定 詳しい 説明する 郵便

class Email {
//---グローバル変数を設定します
var $mailCC = "" // CC
var $mailBCC = ""; CC
var $mailFrom = ""; // 送信者
var $mailSubject = ""; // レター本文のテキスト形式
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() 関数を使用して編集します"," に基づく電子メール アドレス Split
$addressArray =explode( ",",$inAddress);
//--ループを通じて電子メール アドレスの有効性を確認します
for($i=0;$icheckEmail($addressArray[$i])==false) return false; }
//--すべての正当な電子メール アドレスは配列に保存されます
$this- >mailCC = implode($ addressArray, ",");
return true; }
/***************************************************
関数 setBCC($inAddress) は、秘密のカーボン コピー アドレスを設定します。パラメーター $inAddress は、1 つ以上の
メール アドレスを含む文字列です。複数のメール アドレスを区切るには、カンマを使用します。デフォルトの戻り値は
true です。 **** *************************************/
function setBCC($inAddress){
//--explode() 関数を使用して"," に基づく電子メール アドレス
$ addressArray =explode( ",",$inAddress);
//-- ループを通じて電子メール アドレスの有効性を確認します
for($i=0;$i{ if ($this->checkEmail($addressArray[$i])==false)
return false;
}
//--すべての正当な電子メール アドレスは配列
$this に保存されます->mailBCC = implode($ addressArray, ",");
return true
/*************************************************** * *************
関数 setFrom($inAddress): 電子メールを含めるように送信者アドレス パラメーター $inAddress を設定します
アドレス文字列のデフォルトの戻り値は true です
***** ******* *******************************/
function setFrom($inAddress){
if($this->checkEmail($inAddress) )){
$this-> ;mailFrom = $inAddress;
return true; }
/**********************
関数 setSubject($inSubject) は、電子メールの件名パラメータ $inSubject を文字列に設定するために使用されます。
デフォルトの戻り値は true です
**** ***************************************/
function setSubject($inSubject){
if(trim($inSubject) )) > 0){
$this->mailSubject = ereg_replace( "n", "",$inSubject); }
return false; ($inText){
if( strlen(trim($inText)) > 0){
$this->mailText = $inText }
return false;
/***************************************
関数 setHTML($inHTML) はメール本文パラメータ $inHTML を設定しますHTML 形式から HTML 形式へ、
デフォルトの戻り値は true です
*********************************** ********/
function setHTML($inHTML){
if(strlen(trim($inHTML)) > 0){
$this->mailHTML = $inHTML; }
false を返す; }
/**********************
関数 setAttachments($inAttachments) は、電子メールの添付ファイルを設定します。パラメーター $inAttachments は、ディレクトリを含む文字列であり、複数を含むこともできます。ファイルをカンマで区切ります。デフォルトの戻り値は true です
************************************ *********** **/
function setAttachments($inAttachments){
if(strlen(trim($inAttachments)) > 0){
$this->mailAttachments = $inAttachments; true; }
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)は一時ファイルを読み取り、
無駄な情報パラメータを置き換えます $inFileLocationはファイルのディレクトリを見つけるために使用されます
$inHashは一時値を保存するために使用されます $inFormatは配置するために使用されますメール本文
****** *************************************** *********** *** /
function loadTemplate($inFileLocation,$inHash,$inFormat){
/* たとえば、メールには次の内容が含まれています: Dear ~!UserName~ 様、
あなたのアドレスは ~!UserAddress~ */
//--where "~! " は開始マークです。 "~" は終了マークです
$templateDelim = "~";
$templateNameStart = "!";
//-これらの場所を見つけて置き換えます
$templateLineOut = "" / / -- 一時ファイルを開く
if($templateFile = fopen($inFileLocation, "r")){
while(!feof($templateFile)){
$templateLine = fgets($templateFile,1000); explode ($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() でエンコードされた文字列を返します
************************** ***** ****************** */
function getRandomBoundary($offset = 0){
//--乱数生成
srand(time()+$offset);
//-- md5 でエンコードされた 32 ビット文字長の文字列を返す
return ( " -- --".(md5(rand()))); }
/*********************************************
関数: getContentType($inFileName)添付ファイルの種類を決定するために使用されます
****************************************** ****** ***/
function getContentType($inFileName){
//--パスを削除
$inFileName = Basename($inFileName) ;
//--拡張子のないファイルを削除します
if(strrchr($inFileName, ".") == false){
return "application/octet-stream"; 
//--提区扩展名并进行判断
$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"; 
デフォルト: "application/octet-stream" を返します。 
}
return "application/octet-stream"; 
}
/*************************************************
formatTextHeader関数テキストコンテンツを変換します テキストファイルヘッダーを追加します
***************************************** ******* **********/
function formatTextHeader(){ $outTextHeader = ""; 
$outTextHeader .= "Content-Type: text/plain;
charset=us-asciin"; 
$outTextHeader .= "Content-Transfer-Encoding: 7bitnn"; 
$outTextHeader .= $this->メールテキスト。 「ん」; 
$outTextHeader を返す; 
} /**************************************************
機能formatHTMLHeader( )HTML ファイルのヘッダーをメール本文の内容に追加します
************************************ ****** ****/
function formatHTMLHeader(){
$outHTMLHeader = ""; 
$outHTMLHeader .= "Content-Type: text/html;
charset=us-asciin"; 
$outHTMLHeader .= "Content-Transfer-Encoding: 7bitnn"; 
$outHTMLHeader .= $this->mailHTML。 「ん」; 
$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). '"'。 「ん」; 
$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); 
}
//--关闭文件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). '"'。 「ん」; 
//--调用外部コマンドuuencode进行编码
exec( "uuencode -m $inFileLocation nothing_out",$returnArray); 
for ($i = 1; $i$outAttachmentHeader .= $returnArray[$i]。 「ん」; 
}
} $outAttachmentHeader を返します。 
}
/**********************************
関数 send() はメールの送信に使用され、送信に成功すると戻り値は true になります
***** ****************************/
function send(){
//--メールヘッダーを空に設定します
$mailHeader = ""
//-- カーボンコピーの人を追加します
if($this-> ;mailCC != "")
$mailHeader .= "CC: ".$this->mailCC. "n";
//--秘密のカーボンコピー人物を追加
if($this->mailBCC != " ")
$mailHeader .= "BCC: ".$this->mailBCC. "n";
//--送信者を追加
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->formatHTMLHeader();
//--MIME バージョンを設定します
$mailHeader .= "MIME バージョン: 1.0n";
$mailHeader .= "Content-Type: multipart/alternative;n";
$mailHeader .= 'boundary="'.$bodyBoundary. '"'; mailHeader . = "nnn";
//-メール本文と境界を追加します
$mailHeader .= $textHeader .= "-- ". $bodyBoundary. "n";
//--HTML タグを追加します
$mailHeader .= $htmlHeader;
$mailHeader .= "n--".$bodyBoundary. "--";
//--送信email
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->formatTextHeader(); ;formatHTMLHeader ();
$mailHeader .= "MIME バージョン: 1.0n";
$mailHeader .= "Content-Type: multipart/alternative;n"; '" ';
$mailHeader .= "nnn";
$mailHeader .= "--".$bodyBoundary. "n";
$mailHeader .= $textHeader;
$mailHeader .= "--".$bodyBoundary . " n";
$mailHeader .= $htmlHeader;
//--添付ファイルの値を取得します
$attachmentArray( ",", $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-> c.com"); //CC
$mail-> setCC("d@b.com,e@c.com"); //シークレット CC
$mail->setFrom("f @f.com ");//送信者
$mail->setSubject("件名"); //件名
$mail->setText("テキスト形式");//送信テキスト形式は変数にすることもできます
$mail- >setHTML("html format");//送信する HTML 形式は変数にすることもできます
$mail->setAttachments("c:a.jpg");//添付ファイルを追加するには、パスを指定する必要があります
$mail->send() //メールを送信します
?>

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/319229.html技術記事 ?php classEmail{ //---グローバル変数を設定します var$mailTo="";//受信者 var$mailCC="";//Cc var$mailBCC="";//シークレット Cc var$mailFrom =""; //送信者 var$mailSubject="";//件名 var$m...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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