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

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

PHPz
PHPzオリジナル
2023-07-22 10:07:55864ブラウズ

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 までご連絡ください。