Cara menggunakan php untuk melaksanakan fungsi balasan papan mesej

PHPz
Lepaskan: 2023-04-26 18:02:13
asal
1461 orang telah melayarinya

Dengan perkembangan pesat Internet, papan mesej telah menjadi bahagian penting dalam banyak tapak web. Di antara banyak papan mesej, fungsi balasan amat penting kerana ia membolehkan penulis mesej berinteraksi dengan pentadbir laman web, menjadikan komunikasi lebih lancar. Artikel ini akan memperkenalkan cara menggunakan php untuk melaksanakan fungsi balasan papan mesej.

1. Reka bentuk pangkalan data

Sebelum melaksanakan fungsi balasan papan mesej, anda perlu mereka bentuk jadual data untuk menyimpan kandungan mesej dan balasan. Artikel ini menggunakan pangkalan data MySQL Berikut ialah reka bentuk jadual mesej dan jadual balasan:

Jadual mesej (mesej)

列名 数据类型 解释
id int(11) 留言ID
username varchar(20) 留言者姓名
content varchar(255) 留言内容
created_at datetime 留言时间
updated_at datetime 修改时间

Jadual balasan (reply)

列名 数据类型 解释
id int(11) 回复ID
message_id int(11) 留言ID
username varchar(20) 回复者姓名
content varchar(255) 回复内容
created_at datetime 回复时间
updated_at datetime 修改时间

Perkaitan antara jadual mesej dan jadual balasan dicapai melalui message_id, iaitu balasan tertentu sepadan dengan mesej tertentu. Di samping itu, untuk memudahkan pengurusan, dua medan, masa penciptaan dan masa pengubahsuaian, ditambahkan pada setiap mesej dan balasan, yang akan digunakan dalam proses pembangunan seterusnya.

2. Susun atur halaman

Selepas reka bentuk pangkalan data selesai, langkah seterusnya ialah susun atur halaman. Untuk papan mesej, adalah penting bahawa antara muka adalah ringkas, cantik dan mudah digunakan. Artikel ini menggunakan rangka kerja Bootstrap untuk mereka bentuk halaman papan mesej Berikut ialah kod halaman papan mesej:

<!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>
Salin selepas log masuk

Dalam kod di atas, halaman papan mesej dibahagikan kepada dua bahagian, bahagian atas. bahagian ialah kotak mesej, dan bahagian bawah ialah senarai Mesej dan borang balasan. Kedua-dua senarai mesej dan borang balasan dijana secara dinamik. Borang balasan setiap mesej mempunyai medan message_id tersembunyi untuk memudahkan pemprosesan bahagian pelayan.

3. Pelaksanaan back-end

Selepas reka letak halaman selesai, langkah seterusnya ialah pelaksanaan back-end. Dalam artikel ini, kaedah pengaturcaraan PHP berorientasikan objek diguna pakai untuk memudahkan pengembangan dan penyelenggaraan kod. Berikut ialah kod 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);
?>
Salin selepas log masuk

Dalam kod di atas, kelas Mesej dan kelas Balas ditakrifkan, sepadan dengan mesej dan balasan. Dalam kelas Mesej, kaedah statik get_list ditakrifkan untuk mendapatkan senarai mesej dalam kelas Balas, kaedah statik get_list_by_message_id ditakrifkan untuk mendapatkan senarai balasan. Pada masa yang sama, tatasusunan $_POST PHP terbina dalam digunakan untuk memproses data penyerahan borang, dan data mesej dan balasan dimasukkan ke dalam jadual data yang sepadan.

Pada ketika ini, keseluruhan proses melaksanakan fungsi balasan papan mesej dalam PHP telah selesai. Melalui reka bentuk dan pelaksanaan kod di atas, kami boleh melaksanakan fungsi balasan papan mesej dengan mudah, yang meningkatkan pengalaman pengguna dan memudahkan pengurusan laman web.

Atas ialah kandungan terperinci Cara menggunakan php untuk melaksanakan fungsi balasan papan mesej. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan