PHPメール送信クラス
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
1 つ以上の文字列とメール アドレス変数を含めるには、カンマを使用して複数のメール アドレスを区切ります
デフォルトの戻り値は true です
************************************************* * **********/
関数 setTo($inAddress){
//--explode() 関数を使用して、「,」に基づいてメール アドレスを分割します
$addressArray =explode( ",",$inAddress);
//-- ループを通じて電子メール アドレスの有効性を確認します
for($i=0;$i
$this->mailTo = implode($addressArray, ",");
true を返します。
/**************************************************
関数 setCC($inAddress) カーボンコピー担当者のメールアドレスを設定します
パラメーター $inAddress は、1 つ以上の電子メール アドレス、電子メール アドレス変数、
を含む文字列です。
複数の電子メール アドレスを区切るにはカンマを使用します。デフォルトの戻り値は true です。
************************************************* * ************/
関数 setCC($inAddress){
//--explode() 関数を使用して、「,」に基づいてメール アドレスを分割します
$addressArray =explode( ",",$inAddress);
//-- ループを通じて電子メール アドレスの有効性を確認します
for($i=0;$i
$this->mailCC = implode($addressArray, ",");
true を返します。
/****************************************************
関数 setBCC($inAddress) は、秘密のカーボン コピー アドレスを設定します。パラメーター $inAddress には 1 つ以上の
が含まれます。
電子メール アドレスの文字列、電子メール アドレス変数。複数の電子メール アドレスを区切るにはカンマを使用します。デフォルトの戻り値は
です。
本当です
*****************************************/
関数 setBCC($inAddress){
//--explode() 関数を使用して、「,」に基づいてメール アドレスを分割します
$addressArray =explode( ",",$inAddress);
//-- ループを通じて電子メール アドレスの有効性を確認します
for($i=0;$i
false を返します。
}
//--すべての正当な電子メール アドレスは配列に保存されます
$this->mailBCC = implode($addressArray, ",");
true を返します。
}
/*************************************************** * *************
関数 setFrom($inAddress): 送信者のアドレスを設定します。パラメーター $inAddress は、含まれるメールです
アドレス文字列のデフォルトの戻り値は true です
***************************************/
関数 setFrom($inAddress){
if($this->checkEmail($inAddress)){
$this->mailFrom = $inAddress
true を返します。
false を返します。
/***********************
関数 setSubject($inSubject) は、メールの件名パラメーター $inSubject を文字列
に設定するために使用されます。
返されるデフォルト値は true です
******************************************/
関数 setSubject($inSubject){
if(strlen(trim($inSubject)) > 0){
$this->mailSubject = ereg_replace( "n", "",$inSubject);
true を返します。
false を返します。
/************************************************ * **
関数 setText($inText) テキスト形式のメール本文パラメータを設定します $inText はデフォルトのテキストコンテンツです
返還は真です
****************************************/
関数 setText($inText){
if(strlen(trim($inText)) > 0){
$this->mailText = $inText;
true を返します。 }
false を返します。
}
/************************************
関数 setHTML($inHTML) HTML 形式のメール本文パラメータ $inHTML を HTML 形式に設定します
デフォルトの戻り値は true です
*************************************/
関数 setHTML($inHTML){
if(strlen(trim($inHTML)) > 0){
$this->mailHTML = $inHTML;
true を返します。 }
false を返します。 }
/*************************
関数 setAttachments($inAttachments) は電子メールの添付ファイルを設定します パラメーター $inAttachments
これはディレクトリを含む文字列であり、カンマで区切られた複数のファイルを含むこともできます。デフォルトの戻り値は true です。
******************************************/
関数 setAttachments($inAttachments){
if(strlen(trim($inAttachments)) > 0){
$this->mailAttachments = $inAttachments;
true を返します。 }
false を返します。 }
/********************************
関数 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
************************************************* * ***********/
functionloadTemplate($inFileLocation,$inHash,$inFormat){
/* 比如邮件内に以下の内容があります: 親愛なる ~!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
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)== "テキスト" )
return($this->setText($templateLineOut));
else if( strtoupper($inFormat)== "HTML" )
return($this->setHTML($templateLineOut));
} falseを返します。
}
/*****************************************
関数 getRandomBoundary($offset) はランダムな境界値を返します
パラメーター $offset は整数です – マルチパイプライン呼び出しに使用され、md5() でエンコードされた文字列を返します
***************************************/
関数 getRandomBoundary($offset = 0){
//--随机数生成
srand(time()+$offset);
//-- md5 暗号の 32 桁文字列を返します
return ( "----".(md5(rand())));
/*******************************************
関数: getContentType($inFileName) は添付ファイルの種類を決定するために使用されます
*********************************************/
関数 getContentType($inFileName){
//-- パスを削除
$inFileName = ベース名($inFileName);
//--拡張子のないファイルを削除します
if(strrchr($inFileName, ".") == false){
"アプリケーション/オクテットストリーム" を返します
}
//--ゾーン拡張を提案し、判断します
$extension = strrchr($inFileName, ".");
スイッチ($拡張子){
".gif" の場合: "画像/gif" を返します。
case ".gz": "application/x-gzip" を返します
;
case ".htm": "text/html" を返します。
case ".html": "text/html" を返します。
".jpg" の場合: "画像/jpeg" を返します。
case ".tar": "application/x-tar" を返します
;
case ".txt": "text/plain" を返します
;
case ".zip": "アプリケーション/zip" を返します
;
デフォルト: "アプリケーション/オクテットストリーム" を返します。
}
"アプリケーション/オクテットストリーム" を返します
}
/***********************************************
関数 formatTextHeader はテキストコンテンツをテキストファイルヘッダーに追加します
************************************************* * ***/
関数 formatTextHeader(){ $outTextHeader = "";
$outTextHeader .= "コンテンツタイプ: text/plain;
charset=us-asciin";
$outTextHeader .= "コンテンツ転送エンコーディング: 7bitnn";
$outTextHeader .= $this->メールテキスト
;
$outTextHeader を返します。
} /************************************************
関数 formatHTMLHeader() は、HTML ファイルのヘッダーをメール本文に追加します
*****************************************/
関数 formatHTMLHeader(){
$outHTMLHeader = "";
$outHTMLHeader .= "コンテンツタイプ: text/html;
charset=us-asciin";
$outHTMLHeader .= "コンテンツ転送エンコーディング: 7bitnn";
$outHTMLHeader .= $this->メールHTML.
;
$outHTMLHeader を返します。
}
/************************************
関数 formatAttachmentHeader($inFileLocation) は電子メールの添付ファイルを識別します
*******************************/
関数 formatAttachmentHeader($inFileLocation){
$outAttachmentHeader = "";
//--上記の関数 getContentType($inFileLocation) を使用して添付ファイルの種類を取得します
$contentType = $this->getContentType($inFileLocation);
//--添付ファイルがテキストの場合は、標準の 7 桁のエンコードを使用します
if(ereg( "テキスト",$contentType)){
$outAttachmentHeader .= "コンテンツタイプ: ";n";
$outAttachmentHeader .= ' name="'.basename($inFileLocation). '"'. "n";
$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 .= "コンテンツタイプ: ";n";
$outAttachmentHeader .= ' name="'.basename($inFileLocation). '"'. "n";
$outAttachmentHeader .= "コンテンツ転送エンコーディング:base64n";
$outAttachmentHeader .= "コンテンツの配置: 添付ファイル;n";
$outAttachmentHeader .= ' filename="'.basename($inFileLocation). '"'. "nn";
//-- 外部コマンド uuencode を呼び出してエンコードします
exec( "uuencode -m $inFileLocation nothing_out",$returnArray);
for ($i = 1; $i
$outAttachmentHeader .= $returnArray[$i]
;
}
$outAttachmentHeader を返します。
}
/*******************************
send() 関数はメールの送信に使用され、正常に送信された場合の戻り値は true です
***********************************/
関数 send(){
//--メールヘッダーを空に設定します
$mailHeader = "";
//--CC を追加
if($this->mailCC != "")
$mailHeader .= "CC: ".$this->mailCC
;
//--秘密のカーボンコピー担当者を追加
if($this->mailBCC != "")
$mailHeader .= "BCC: ".$this->mailBCC
;
//--送信者を追加
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 .= ' 境界="'.$bodyBoundary. '"';
$mailHeader .= "nnn";
//--メール本文と境界線を追加します
$mailHeader .= "--".$bodyBoundary
;
$mailHeader .= $textHeader
$mailHeader .= "--".$bodyBoundary
;
//--HTML タグを追加します
$mailHeader .= $htmlHeader;
$mailHeader .= "n--".$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. '"'
;
$mailHeader .= "これは MIME 形式のマルチパート メッセージです。n";
$mailHeader .= "--".$attachmentBoundary
;
$bodyBoundary = $this->getRandomBoundary(1);
$textHeader = $this->formatTextHeader();
$htmlHeader = $this->formatHTMLHeader();
$mailHeader .= "MIME バージョン: 1.0n";
$mailHeader .= "Content-Type: multipart/alternative;n";
$mailHeader .= ' 境界="'.$bodyBoundary. '"';
$mailHeader .= "nnn";
$mailHeader .= "--".$bodyBoundary
;
$mailHeader .= $textHeader
$mailHeader .= "--".$bodyBoundary
;
$mailHeader .= $htmlHeader;
$mailHeader .= "n--".$bodyBoundary
;
//--添付ファイルの値を取得します
$attachmentArray =explode( ",",$this->mailAttachments);
//--添付ファイルの数に基づいてループします
for($i=0;$i
;
//--添付ファイル情報
$mailHeader .= $this->formatAttachmentHeader($attachmentArray[$i]);
}
$mailHeader .= "--".$attachmentBoundary
;
return mail($this->mailTo,$this->mailSubject, "",$mailHeader);
}
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”);//送信者
$mail->setSubject("件名") //件名
;
$mail->setText("テキスト形式") ;//送信テキスト形式は変数にすることもできます
$mail->setHTML("html format") ;//送信する HTML 形式を変数にすることもできます
$mail->setAttachments("c:a.jpg") ;//添付ファイルを追加するには、パスを指定する必要があります
$mail->send(); //メールを送信する
以上、PHPのメール送信クラスを内容も含めて紹介しましたが、PHPチュートリアルに興味のある友人の参考になれば幸いです。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











ログイン画面に「組織から PIN の変更を求められています」というメッセージが表示されます。これは、個人のデバイスを制御できる組織ベースのアカウント設定を使用しているコンピューターで PIN の有効期限の制限に達した場合に発生します。ただし、個人アカウントを使用して Windows をセットアップした場合、エラー メッセージは表示されないのが理想的です。常にそうとは限りませんが。エラーが発生したほとんどのユーザーは、個人アカウントを使用して報告します。私の組織が Windows 11 で PIN を変更するように要求するのはなぜですか?アカウントが組織に関連付けられている可能性があるため、主なアプローチはこれを確認することです。ドメイン管理者に問い合わせると解決できます。さらに、ローカル ポリシー設定が間違っていたり、レジストリ キーが間違っていたりすると、エラーが発生する可能性があります。今すぐ

Windows 11 では、新鮮でエレガントなデザインが前面に押し出されており、最新のインターフェイスにより、ウィンドウの境界線などの細部をカスタマイズして変更することができます。このガイドでは、Windows オペレーティング システムで自分のスタイルを反映した環境を作成するのに役立つ手順について説明します。ウィンドウの境界線の設定を変更するにはどうすればよいですか? + を押して設定アプリを開きます。 Windows [個人用設定] に移動し、[色の設定] をクリックします。ウィンドウの境界線の色の変更設定ウィンドウ 11" width="643" height="500" > [タイトル バーとウィンドウの境界線にアクセント カラーを表示する] オプションを見つけて、その横にあるスイッチを切り替えます。 [スタート] メニューとタスク バーにアクセント カラーを表示するにはスタート メニューとタスク バーにテーマの色を表示するには、[スタート メニューとタスク バーにテーマを表示] をオンにします。

デフォルトでは、Windows 11 のタイトル バーの色は、選択したダーク/ライト テーマによって異なります。ただし、任意の色に変更できます。このガイドでは、デスクトップ エクスペリエンスを変更し、視覚的に魅力的なものにするためにカスタマイズする 3 つの方法について、段階的な手順を説明します。アクティブなウィンドウと非アクティブなウィンドウのタイトル バーの色を変更することはできますか?はい、設定アプリを使用してアクティブなウィンドウのタイトル バーの色を変更したり、レジストリ エディターを使用して非アクティブなウィンドウのタイトル バーの色を変更したりできます。これらの手順を学習するには、次のセクションに進んでください。 Windows 11でタイトルバーの色を変更するにはどうすればよいですか? 1. 設定アプリを使用して + を押して設定ウィンドウを開きます。 Windows「個人用設定」に進み、

タスクバーのサムネイルは楽しい場合もありますが、気が散ったり煩わしい場合もあります。この領域にマウスを移動する頻度を考えると、重要なウィンドウを誤って閉じてしまったことが何度かある可能性があります。もう 1 つの欠点は、より多くのシステム リソースを使用することです。そのため、リソース効率を高める方法を探している場合は、それを無効にする方法を説明します。ただし、ハードウェアの仕様が対応可能で、プレビューが気に入った場合は、有効にすることができます。 Windows 11でタスクバーのサムネイルプレビューを有効にする方法は? 1. 設定アプリを使用してキーをタップし、[設定] をクリックします。 Windows では、「システム」をクリックし、「バージョン情報」を選択します。 「システムの詳細設定」をクリックします。 [詳細設定] タブに移動し、[パフォーマンス] の下の [設定] を選択します。 「視覚効果」を選択します

Windows インストーラー ページに「問題が発生しました」というメッセージとともに「OOBELANGUAGE」というメッセージが表示されますか?このようなエラーが原因で Windows のインストールが停止することがあります。 OOBE とは、すぐに使えるエクスペリエンスを意味します。エラー メッセージが示すように、これは OOBE 言語の選択に関連する問題です。心配する必要はありません。OOBE 画面自体から気の利いたレジストリ編集を行うことで、この問題を解決できます。クイックフィックス – 1. OOBE アプリの下部にある [再試行] ボタンをクリックします。これにより、問題が発生することなくプロセスが続行されます。 2. 電源ボタンを使用してシステムを強制的にシャットダウンします。システムの再起動後、OOBE が続行されます。 3. システムをインターネットから切断します。 OOBE のすべての側面をオフライン モードで完了する

Windows 11 のディスプレイ スケーリングに関しては、好みが人それぞれ異なります。大きなアイコンを好む人もいれば、小さなアイコンを好む人もいます。ただし、適切なスケーリングが重要であることには誰もが同意します。フォントのスケーリングが不十分であったり、画像が過度にスケーリングされたりすると、作業中の生産性が大幅に低下する可能性があるため、システムの機能を最大限に活用するためにカスタマイズする方法を知る必要があります。カスタム ズームの利点: これは、画面上のテキストを読むのが難しい人にとって便利な機能です。一度に画面上でより多くの情報を確認できるようになります。特定のモニターおよびアプリケーションにのみ適用するカスタム拡張プロファイルを作成できます。ローエンド ハードウェアのパフォーマンスの向上に役立ちます。画面上の内容をより詳細に制御できるようになります。 Windows 11の使用方法

画面の明るさは、最新のコンピューティング デバイスを使用する上で不可欠な部分であり、特に長時間画面を見る場合には重要です。目の疲れを軽減し、可読性を向上させ、コンテンツを簡単かつ効率的に表示するのに役立ちます。ただし、設定によっては、特に新しい UI が変更された Windows 11 では、明るさの管理が難しい場合があります。明るさの調整に問題がある場合は、Windows 11 で明るさを管理するすべての方法を次に示します。 Windows 11で明るさを変更する方法【10の方法を解説】 シングルモニターユーザーは、次の方法でWindows 11の明るさを調整できます。これには、ラップトップだけでなく、単一のモニターを使用するデスクトップ システムも含まれます。はじめましょう。方法 1: アクション センターを使用する アクション センターにアクセスできる

Windows のライセンス認証プロセスが突然切り替わり、このエラー コード 0xc004f069 を含むエラー メッセージが表示されることがあります。ライセンス認証プロセスはオンラインですが、Windows Server を実行している一部の古いシステムではこの問題が発生する可能性があります。これらの初期チェックを実行し、システムのアクティブ化に役に立たない場合は、問題を解決するための主要な解決策に進んでください。回避策 – エラー メッセージとアクティベーション ウィンドウを閉じます。次に、コンピュータを再起動します。 Windows ライセンス認証プロセスを最初から再試行します。解決策 1 – ターミナルからアクティブ化する cmd ターミナルから Windows Server Edition システムをアクティブ化します。ステージ – 1 Windows Server のバージョンを確認する 使用している W の種類を確認する必要があります
