class Email {
//--- グローバル変数を設定します
var $mailTo = ""; // 受信者
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;$i
//--すべての有効な電子メール アドレスは配列に保存されます
$this-> ($addressArray, ",");
return true; }
/**************************************************
機能setCC($inAddress) は、カーボン コピー者の電子メール アドレスを設定します
パラメーター $inAddress は、1 つ以上の電子メール アドレスを含む文字列、電子メール アドレス変数です。
複数の電子メール アドレスを区切るにはカンマを使用します。デフォルトの戻り値は true です
**** ********************************************* ***** ********/
function setCC($inAddress){
//--explode() 関数を使用して、", " アドレスを分割します
$addressArray =explode( ",",$inAddress);
//--ループを通じて電子メール アドレスの有効性をチェックします
for($i=0;$i
//--すべての正当な電子メール アドレスは配列に保存されます
$this->mailCC = implode ($addressArray, ",");
return true; }
/****************************************************
関数 setBCC($inAddress) は、シークレット カーボン コピー アドレス パラメーター $inAddress を 1 つ以上の
メール アドレスを含む文字列に設定します。メール アドレス変数。複数のメール アドレスを区切るにはカンマを使用します。デフォルトの戻り値は
true
**** *************************************/
function setBCC($inAddress){
//--explode() 関数を使用して、 ","
$addressArray =explode( ",",$inAddress);
//-- ループを通じて電子メール アドレスの有効性を確認します
for($i=0;$i
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 を文字列に設定するために使用されます。
デフォルトの戻り値は次のとおりです。本当です
**** ***************************************/
function setSubject($inSubject){
if(strlen(trim($inSubject)) > 0) {
$this->mailSubject = ereg_replace( "n", "",$inSubject);
return false;
/*************************************************** *
関数 setText($inText) は、メール本文パラメータ $inText をテキスト形式で設定します。
******************* のデフォルトの戻り値。 *********** *****************/
function setText($inText) {
if(strlen(trim($inText)) > 0){
$this->mailText = $inText; }
return false;
/***************************************
関数 setHTML($inHTML) はメール本文パラメータ $inHTML を設定しますHTML 形式から HTML 形式へ、
デフォルトの戻り値は true です
*********************************** ********/
関数setHTML( $inHTML){
if(strlen(trim($inHTML)) > 0){
$this->mailHTML = $inHTML; }
/**********************
関数 setAttachments($inAttachments) は、電子メールの添付ファイル パラメーターを設定します。 $inAttachments は、ディレクトリを含む文字列であり、含めることもできます。複数のファイルの場合、カンマ区切りのデフォルトの戻り値は true です
************************************ *********** * */
function setAttachments($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) 一時ファイルを読み取り、
不要な情報を置き換えます パラメータ $inFileLocation はファイルのディレクトリを見つけるために使用されます
$inHash は一時値を保存するために使用されます $inFormat は配置に使用されますメール本文
****** *************************************** *********** ***/
function loadTemplate($inFileLocation,$inHash,$inFormat){
/ * たとえば、メールには次の内容が含まれます: Dear ~!UserName~
Your address is ~!UserAddress~ */
//--「~!」は開始マーク、「~」は終了マーク
$templateDelim = "~ ";
$templateNameStart = "!";
//--これらの場所を見つけて置換します
$templateLineOut = "" //--一時ファイルを開きます
if($templateFile = fopen($; inFileLocation, " r")){
while(!feof($templateFile)){
$templateLine = fgets($templateFile,1000) =explode($templateDelim,$templateLine); 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));
} return false;
/******************************************
関数 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, "."); ($extension){
case ".gif": return "image/gif";
case ".gz": return "application/x-gzip";
case ".htm": return "text/html"; case ".html": "text/html" を返します。
case ".jpg": "image/jpeg" を返します。
case ".txt" を返します。 return "text/plain";
case ".zip": return "application/octet-stream";
return "application/octet-stream"; ***********************************************
関数 formatTextHeader は変換しますテキストの内容 テキストファイルのヘッダーを追加します
***************************************** ****** **********/
function formatTextHeader(){ $outTextHeader = "";
$outTextHeader .= "Content-Type: text/plain;
charset=us-asciin";
$outTextHeaderエンコーディング: 7bitnn";
$outTextHeader .= $this->mailText. "n";
return $outTextHeader;
} /**************************************************
機能formatHTMLHeader( )HTMLファイルのヘッダーをメール本文に追加します
************************************ ***** ****/
function formatHTMLHeader(){
$outHTMLHeader = "";
$outHTMLHeader .= "Content-Type: 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( "text",$contentType){
$ outAttachmentHeader .= "コンテンツ タイプ: ".$contentType. ";n";
$outAttachmentHeader .= ' name="'.basename($inFileLocation). '"' .= "コンテンツ- Transfer-Encoding: 7bitn";
$outAttachmentHeader .= "Content-Disposition:attachment;n";
$outAttachmentHeader .= ' filename="'.basename($inFileLocation) '"'. "nn";
$ 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). '"'. "n";
$outAttachmentHeader .= "コンテンツ転送エンコーディング: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 ]. "n";
}
} return $outAttachmentHeader;
/**********************************
関数 send() はメールの送信に使用され、戻り値は true です。送信は成功しました
***** *****************************/
//--メールヘッダーを空に設定します
$mailHeader = " ";
/ /-CC 人物を追加
if($this->mailCC != "")
$mailHeader .= "CC: ".$this->mailCC. "n";
//--秘密のコピーを追加 誰かに送信します
if($this->mailBCC != "")
$mailHeader .= "BCC: ".$this->mailBCC. "n";
//--送信者を追加します
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(); formatHTMLHeader();
//--MIME バージョンを設定します
$mailHeader .= "MIME-Version: 1.0n";
$mailHeader .= "Content-Type: multipart/alternative;n"; border="'.$bodyBoundary. '"';
$mailHeader .= "nnn";
$mailHeader .= "-".$bodyBoundary
$; mailHeader .= $textHeader;
$mailHeader .= "--".$bodyBoundary. "n";
$mailHeader .= $htmlHeader .= "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. "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 .= "--".$bodyBoundary .= $ textHeader;
$mailHeader .= "-".$bodyBoundary.
$mailHeader .= "--".$bodyBoundary; -添付ファイルの値を取得します
$attachmentArray =explode( ",",$this->mailAttachments);
//--添付ファイルの数に応じてループします
for($i=0;$i
//--添付ファイル情報
$mailHeader .= $this->formatAttachmentHeader($attachmentArray) [ $i]);
}
$mailHeader .= "--".$attachmentBoundary. "--";
return mail($this->mailTo,$this->mailSubject, "",$mailHeader) ;
}
return false;
}
}
?>
$mail->setTo("a@a.com") //受信者
$mail-> c@c.com"); //Cc
$mail-> ; setCC("d@b.com,e@c.com"); //シークレットCC
$mail->setFrom("f@f .com"); //Sender
$mail->setSubject("Subject"); //件名
$mail->setText("Text Format");//送信テキスト形式は変数にすることもできます
$mail->setHTML("html format");// 送信する HTML 形式は変数にすることもできます
$mail->setAttachments("c:a.jpg"); // 添付ファイルを追加するには、パスを次のように指定する必要があります。指定
$mail->send(); //メールを送信します

phpssionsStrackuserdataacrossmultiplepagerequestsusingauniqueidstoredinacookie.here'showtomanageetheemefectively:1)Startassession withsession_start()andstoredatain $ _ session.2)RegeneratesseSsessidafterloginwithsession_id(the topreventes_id)

PHPでは、次の手順を通じてセッションデータを繰り返すことができます。1。session_start()を使用してセッションを開始します。 2。$ _Sessionアレイのすべてのキー価値ペアを介してforeachループを反復します。 3.複雑なデータ構造を処理する場合、is_array()またはis_object()関数を使用し、print_r()を使用して詳細情報を出力します。 4.トラバーサルを最適化する場合、ページングを使用して、一度に大量のデータの処理を避けることができます。これにより、実際のプロジェクトでPHPセッションデータをより効率的に管理および使用するのに役立ちます。

このセッションは、サーバー側の状態管理メカニズムを介してユーザー認証を実現します。 1)セッションの作成と一意のIDの生成、2)IDはCookieを介して渡されます。3)サーバーストアとIDを介してセッションデータにアクセスします。

tostoreauser'snameInappession、starthessession withsession_start()、thensignthenameto $ _session ['username']。1)ousession_start()toinitializethessession.2)assighttheuser'snameto $ _ session ['username']

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

ホットトピック









