PHP implements message board function
With the popularity of the Internet, website message boards have become a must-have feature for many websites. There are many ways to implement message boards, one of the more common ones is to use PHP. This article will introduce how to use PHP to implement message board functions.
1. Front-end page design
Before implementing the message board, we need to design the front-end page first. A typical message board page usually contains the following parts:
1. Message input box: used to enter message content.
2. Message list: used to display existing messages.
3. Message submission button: used to submit messages.
Based on the above requirements, we can design a message board HTML page with the following code:
<!DOCTYPE html> <html> <head> <title>留言板</title> </head> <body> <h1>留言板</h1> <!-- 留言输入框 --> <form action="save_message.php" method="post"> <label for="name">姓名:</label> <input type="text" id="name" name="name"><br> <label for="message">留言内容:</label> <textarea id="message" name="message" rows="5" cols="50"></textarea><br> <input type="submit" value="提交留言"> </form> <hr> <!-- 留言列表 --> <h2>留言列表</h2> <?php // TODO: 展示留言列表 ?> </body> </html>
Among them, the action
attribute of the form points to a save_message. php
file. This file will implement the functions of accepting submitted messages and displaying the message list.
2. Save the message
Next, we need to implement the logic of the save_message.php
file to accept data from the message board HTML page and save them in the database. The specific steps are as follows:
1. Create a MySQL database
In the MySQL database, we need to create a database named guestbook
, and a database named messages The
table is used to save messages. The structure of the table is as follows:
CREATE TABLE `messages` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `message` text NOT NULL, `created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2. Write PHP code
Next, let’s write the code for the save_message.php
file. This file needs to complete the following tasks:
- Receive the user name and message content from the form.
- Save these data to the
messages
table in the MySQL database. - Display a prompt message indicating successful saving.
The code is as follows:
<?php // 从表单中接收数据 $name = $_POST['name']; $message = $_POST['message']; // 连接数据库 $dsn = 'mysql:host=localhost;dbname=guestbook'; $username = 'root'; $password = ''; $db = new PDO($dsn, $username, $password); // 插入留言 $sql = "INSERT INTO messages (name, message) VALUES (:name, :message)"; $stmt = $db->prepare($sql); $stmt->bindParam(':name', $name); $stmt->bindParam(':message', $message); $stmt->execute(); // 输出提示信息 echo '留言保存成功!';
3. Display the message list
Now, we can save the data from the message board HTML page to the MySQL database . Next, we need to modify the HTML page to display the existing message content.
The modified HTML code is as follows:
<!DOCTYPE html> <html> <head> <title>留言板</title> </head> <body> <h1>留言板</h1> <!-- 留言输入框 --> <form action="save_message.php" method="post"> <label for="name">姓名:</label> <input type="text" id="name" name="name"><br> <label for="message">留言内容:</label> <textarea id="message" name="message" rows="5" cols="50"></textarea><br> <input type="submit" value="提交留言"> </form> <hr> <!-- 留言列表 --> <h2>留言列表</h2> <?php // 连接数据库 $dsn = 'mysql:host=localhost;dbname=guestbook'; $username = 'root'; $password = ''; $db = new PDO($dsn, $username, $password); // 查询留言 $sql = "SELECT * FROM messages ORDER BY created_at DESC"; $stmt = $db->query($sql); $messages = $stmt->fetchAll(); // 展示留言 foreach ($messages as $message) { echo "<p><strong>{$message['name']}:</strong>{$message['message']}</p>"; } ?> </body> </html>
In this code, we first connect to the MySQL database, and then query all the messages in the messages
table, and sort them according to time Sort. Finally, display all messages in a loop.
To sum up, it is not difficult to use PHP to implement the message board function, and the effect is great. I hope this article can be helpful to PHP beginners.
The above is the detailed content of PHP implements message board function. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

Validator can be created by adding the following two lines in the controller.
