ホームページ バックエンド開発 PHPチュートリアル PHP および PHPMAILER を使用して Web サイトでの電子メール送信のブラックリスト管理機能を実装する方法を学習します。

PHP および PHPMAILER を使用して Web サイトでの電子メール送信のブラックリスト管理機能を実装する方法を学習します。

Jul 22, 2023 am 10:07 AM
php phpmailer 電子メールブラックリスト管理

PHP および PHPMailer を使用して Web サイトに電子メール送信のブラックリスト管理機能を実装する方法を学習します

Web サイト開発者として、Web サイトに電子メール送信機能を実装することが必要になることがよくあります。電子メールの送信は、Web サイト ユーザーと Web サイト間のコミュニケーションのための重要な方法です。ただし、場合によっては、特定のユーザーまたは電子メール アドレスによる当社サイトへの電子メールの送信を制限する必要がある場合があります。

この機能を実現するには、PHP と PHPMailer を使用してブラックリストを管理し、特定のユーザーまたは電子メール アドレスをブラックリストに追加して、電子メールの送信権限を制限します。この記事では、PHP と PHPMailer を使用してブラックリスト管理機能を実装する方法を学びます。

まず、電子メールの送信が制限されているユーザーまたは電子メール アドレスを保存するブラックリストを作成する必要があります。データベース テーブルを使用して、これらのブラックリスト リストを保存できます。このテーブルには、ブラックリスト ID、ユーザーまたは電子メール アドレス、ブラックリストに追加された時刻などのフィールドが含まれています。以下は、ブラックリスト リストを作成するサンプル SQL ステートメントです:

CREATE TABLE blacklist (
    id INT(11) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    email VARCHAR(255) NOT NULL,
    added_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
ログイン後にコピー

次に、PHP を使用してデータベースに接続し、ブラックリスト内のユーザーまたは電子メール アドレスを追加、削除、確認するための対応する関数を作成します。まず、データベースに接続する必要があります。次のコードを使用できます。

<?php
$servername = "localhost";
$username = "root";
$password = "your_password";
$dbname = "your_database";

// 创建数据库连接
$conn = new mysqli($servername, $username, $password, $dbname);

// 检查连接是否成功
if ($conn->connect_error) {
    die("数据库连接失败:" . $conn->connect_error);
}
?>
ログイン後にコピー

次に、ユーザーまたは電子メール アドレスをブラックリストに追加する関数を作成します。関数の例を次に示します。

function addToBlackList($email)
{
    // 全局变量$conn是数据库连接对象

    // 检查邮箱是否已经在黑名单中
    $sql = "SELECT id FROM blacklist WHERE email='$email'";
    $result = $conn->query($sql);

    if ($result->num_rows > 0) {
        // 邮箱已经在黑名单中
        return false;
    } else {
        // 将邮箱添加到黑名单
        $sql = "INSERT INTO blacklist (email) VALUES ('$email')";
        if ($conn->query($sql) === TRUE) {
            return true;
        } else {
            return false;
        }
    }
}
ログイン後にコピー

次に、ユーザーまたは電子メール アドレスをブラックリストから削除する関数を作成します。関数の例を次に示します。

function removeFromBlackList($email)
{
    // 全局变量$conn是数据库连接对象

    // 从黑名单中删除邮箱
    $sql = "DELETE FROM blacklist WHERE email='$email'";
    if ($conn->query($sql) === TRUE) {
        return true;
    } else {
        return false;
    }
}
ログイン後にコピー

最後に、ユーザーまたは電子メール アドレスがブラックリストに含まれているかどうかを確認する必要があります。以下は関数の例です。

function checkBlackList($email)
{
    // 全局变量$conn是数据库连接对象

    // 检查邮箱是否在黑名单中
    $sql = "SELECT id FROM blacklist WHERE email='$email'";
    $result = $conn->query($sql);

    if ($result->num_rows > 0) {
        // 邮箱在黑名单中
        return true;
    } else {
        // 邮箱不在黑名单中
        return false;
    }
}
ログイン後にコピー

これで、ブラックリストを管理する関数が正常に作成されました。次に、PHPMailer を使用してメール送信機能を実装し、送信前に送信者がブラックリストに含まれているかどうかを確認します。以下はサンプル コードです:

<?php
require 'phpmailer/PHPMailerAutoload.php';

// 创建邮件对象
$mail = new PHPMailer;

// 配置SMTP服务器
$mail->isSMTP();
$mail->Host = 'smtp.yourdomain.com';
$mail->SMTPAuth = true;
$mail->Username = 'your_email@example.com';
$mail->Password = 'your_password';
$mail->SMTPSecure = 'tls';
$mail->Port = 587;

// 设置发送方和收件人
$mail->setFrom('your_email@example.com', 'Your Name');
$mail->addAddress('recipient@example.com', 'Recipient Name');

// 设置邮件内容和主题
$mail->Subject = 'Hello from PHPMailer';
$mail->Body    = 'This is the HTML message body <b>in bold!</b>';

// 检查发送者是否在黑名单中
if (checkBlackList('your_email@example.com')) {
    echo "您不能发送邮件。";
} else {
    // 发送邮件
    if (!$mail->send()) {
        echo '邮件发送失败: ' . $mail->ErrorInfo;
    } else {
        echo '邮件发送成功!';
    }
}
?>
ログイン後にコピー

上の例では、最初に SMTP サーバーとメールの送信者と受信者を構成しました。次に、checkBlackList() 関数を使用して、送信者がブラックリストに含まれているかどうかを確認します。送信者がブラックリストに含まれている場合は、送信が失敗したことを示すプロンプト メッセージが出力されます。それ以外の場合は、PHPMailer を使用して電子メールが送信されます。

上記のサンプルコードにより、ブラックリスト管理機能を実装し、電子メールを送信する前に送信者がブラックリストに含まれているかどうかを確認することができます。このようにして、特定のユーザーまたは電子メール アドレスが当社の Web サイトに電子メールを送信することを制限できます。

要約すると、PHP と PHPMailer を介して、電子メール送信のブラックリスト管理機能を簡単に実装できます。ブラックリスト管理機能を通じて、当社の Web サイトのセキュリティとユーザー エクスペリエンスを保護するために、特定のユーザーまたは電子メール アドレスが当社の Web サイトに電子メールを送信することを制限できます。この記事があなたのお役に立てば幸いです、読んでいただきありがとうございます!

以上がPHP および PHPMAILER を使用して Web サイトでの電子メール送信のブラックリスト管理機能を実装する方法を学習します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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:27 PM

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

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

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

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

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

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

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

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

See all articles