ホームページ  >  記事  >  バックエンド開発  >  phpを使って掲示板の返信機能を実装する方法

phpを使って掲示板の返信機能を実装する方法

PHPz
PHPzオリジナル
2023-04-26 18:00:561381ブラウズ

インターネットの急速な発展に伴い、掲示板は多くの Web サイトにとって不可欠な部分となっています。数ある掲示板の中でも返信機能は、メッセージ作成者とWebサイト管理者とのやり取りを可能にし、コミュニケーションをよりスムーズにするため、特に重要です。この記事ではphpを使って掲示板の返信機能を実装する方法を紹介します。

1. データベース設計

掲示板返信機能を実装する前に、まずメッセージと返信内容を格納するデータテーブルを設計する必要があります。この記事では MySQL データベースを使用します。メッセージ テーブルと応答テーブルの設計は次のとおりです:

メッセージ テーブル (メッセージ)

##idint(11)メッセージIDusernamevarchar(20)コメント投稿者の名前contentcreated_at updated_at返信テーブル (返信)
カラム名 データ型 説明
# #varchar( 255) メッセージの内容
datetime メッセージ時刻
datetime 変更時刻

#列名##idint(11)返信 IDmessage_idint(11)メッセージ IDユーザー名varchar(20)返信者名contentvarchar(255)返信内容created_atdatetime返信時間updated_atdatetime変更時刻メッセージ テーブルと応答テーブル間の関連付けは、message_id によって実現されます。つまり、特定の応答は特定のメッセージに対応します。さらに、管理を容易にするために、各メッセージと返信に作成時刻と変更時刻の 2 つのフィールドが追加され、後の開発プロセスで使用されます。
データ型 説明
2. ページ レイアウト

データベースの設計が完了したら、次のステップはページ レイアウトです。掲示板の場合、インターフェイスがシンプルで美しく、使いやすいことが重要です。この記事では、Bootstrap フレームワークを使用してメッセージ ボード ページをデザインします。メッセージ ボード ページのコードは次のとおりです:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>留言板</title>
    <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css">
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
    <div class="container">
        <h2>留言板</h2>
        <form class="form-horizontal" method="post" action="post_message.php">
            <div class="form-group">
                <label for="username" class="col-sm-2 control-label">姓名:</label>
                <div class="col-sm-10">
                    <input type="text" name="username" class="form-control" required>
                </div>
            </div>
            <div class="form-group">
                <label for="content" class="col-sm-2 control-label">留言内容:</label>
                <div class="col-sm-10">
                    <textarea name="content" class="form-control" rows="5" required></textarea>
                </div>
            </div>
            <div class="form-group">
                <div class="col-sm-offset-2 col-sm-10">
                    <button type="submit" class="btn btn-primary">提交</button>
                </div>
            </div>
        </form>
        <?php
            // 查询留言列表
            $sql = "SELECT * FROM message ORDER BY created_at DESC";
            $result = mysqli_query($conn, $sql);
            while ($row = mysqli_fetch_assoc($result)) {
        ?>
        <div class="panel panel-default">
            <div class="panel-heading">
                <?php echo $row[&#39;username&#39;]; ?>(<?php echo $row[&#39;created_at&#39;]; ?>)
            </div>
            <div class="panel-body">
                <?php echo $row[&#39;content&#39;]; ?>
            </div>
        </div>
        <?php
                // 查询回复列表
                $sql = "SELECT * FROM reply WHERE message_id = {$row[&#39;id&#39;]} ORDER BY created_at ASC";
                $result2 = mysqli_query($conn, $sql);
                while ($row2 = mysqli_fetch_assoc($result2)) {
        ?>
        <div class="panel panel-info">
            <div class="panel-heading">
                <?php echo $row2[&#39;username&#39;]; ?>(<?php echo $row2[&#39;created_at&#39;]; ?>)
            </div>
            <div class="panel-body">
                <?php echo $row2[&#39;content&#39;]; ?>
            </div>
        </div>
        <?php
                }
        ?>
        <form class="form-horizontal" method="post" action="post_reply.php">
            <div class="form-group">
                <div class="col-sm-offset-2 col-sm-10">
                    <input type="hidden" name="message_id" value="<?php echo $row[&#39;id&#39;]; ?>">
                    <input type="text" name="username" class="form-control" placeholder="回复者姓名" required>
                </div>
            </div>
            <div class="form-group">
                <div class="col-sm-offset-2 col-sm-10">
                    <textarea name="content" class="form-control" rows="3" placeholder="回复内容" required></textarea>
                </div>
            </div>
            <div class="form-group">
                <div class="col-sm-offset-2 col-sm-10">
                    <button type="submit" class="btn btn-default">回复</button>
                </div>
            </div>
        </form>
        <?php
            }
        ?>
    </div>
</body>
</html>
上記のコードでは、メッセージ ボード ページは 2 つの部分に分かれており、上の部分はメッセージボックス、下部がメッセージ一覧と返信フォームです。メッセージ リストと返信フォームは両方とも動的に生成され、各メッセージの返信フォームにはサーバー側の処理を容易にする非表示の message_id フィールドがあります。

3. バックエンドの実装

ページ レイアウトが完了したら、次のステップはバックエンドの実装です。この記事では、コードの拡張と保守を容易にするために、オブジェクト指向 PHP プログラミング手法が採用されています。以下は PHP コードです。

<?php
// 建立数据库连接
$conn = new mysqli("localhost", "root", "password", "test");
if ($conn->connect_error) {
    die("数据库连接失败:" . $conn->connect_error);
}

// 定义Message类
class Message {
    public $id;
    public $username;
    public $content;
    public $created_at;
    public $updated_at;
    
    // 构造函数
    function __construct($id, $username, $content, $created_at, $updated_at) {
        $this->id = $id;
        $this->username = $username;
        $this->content = $content;
        $this->created_at = $created_at;
        $this->updated_at = $updated_at;
    }
    
    // 静态方法:获取留言列表
    static function get_list($conn) {
        $messages = array();
        $sql = "SELECT * FROM message ORDER BY created_at DESC";
        $result = mysqli_query($conn, $sql);
        while ($row = mysqli_fetch_assoc($result)) {
            $message = new Message($row['id'], $row['username'], $row['content'], $row['created_at'], $row['updated_at']);
            array_push($messages, $message);
        }
        return $messages;
    }
}

// 定义Reply类
class Reply {
    public $id;
    public $message_id;
    public $username;
    public $content;
    public $created_at;
    public $updated_at;
    
    // 构造函数
    function __construct($id, $message_id, $username, $content, $created_at, $updated_at) {
        $this->id = $id;
        $this->message_id = $message_id;
        $this->username = $username;
        $this->content = $content;
        $this->created_at = $created_at;
        $this->updated_at = $updated_at;
    }
    
    // 静态方法:根据留言ID获取回复列表
    static function get_list_by_message_id($conn, $message_id) {
        $replies = array();
        $sql = "SELECT * FROM reply WHERE message_id = {$message_id} ORDER BY created_at ASC";
        $result = mysqli_query($conn, $sql);
        while ($row = mysqli_fetch_assoc($result)) {
            $reply = new Reply($row['id'], $row['message_id'], $row['username'], $row['content'], $row['created_at'], $row['updated_at']);
            array_push($replies, $reply);
        }
        return $replies;
    }
}

// 处理留言提交
if ($_SERVER['REQUEST_METHOD'] == 'POST' && !empty($_POST['username']) && !empty($_POST['content'])) {
    $sql = "INSERT INTO message (username, content) VALUES ('{$_POST['username']}', '{$_POST['content']}')";
    mysqli_query($conn, $sql);
}

// 处理回复提交
if ($_SERVER['REQUEST_METHOD'] == 'POST' && !empty($_POST['message_id']) && !empty($_POST['username']) && !empty($_POST['content'])) {
    $sql = "INSERT INTO reply (message_id, username, content) VALUES ({$_POST['message_id']}, '{$_POST['username']}', '{$_POST['content']}')";
    mysqli_query($conn, $sql);
}

// 获取留言列表
$messages = Message::get_list($conn);
?>
上記のコードでは、メッセージと返信に対応する Message クラスと Reply クラスが定義されています。 Message クラスでは、メッセージ リストを取得するための静的メソッド get_list が定義され、Reply クラスでは、応答リストを取得するための静的メソッド get_list_by_message_id が定義されています。同時に、PHP の組み込み $_POST 配列を使用してフォーム送信データが処理され、メッセージと返信のデータが対応するデータ テーブルに挿入されます。

この時点で、PHP で掲示板への返信機能を実装するプロセス全体が完了しました。上記のコードを設計して実装することで、掲示板への返信機能を簡単に実装でき、ユーザー エクスペリエンスが向上し、Web サイトの管理が容易になります。

以上がphpを使って掲示板の返信機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。