Maison > développement back-end > tutoriel php > PHP implémente les fonctions de discussion des questions et d'édition des réponses sur le site Web de questions et réponses de connaissances.

PHP implémente les fonctions de discussion des questions et d'édition des réponses sur le site Web de questions et réponses de connaissances.

WBOY
Libérer: 2023-07-02 19:10:01
original
1439 Les gens l'ont consulté

PHP réalise les fonctions de discussion des questions et d'édition des réponses sur le site Web de questions-réponses sur les connaissances.

À l'ère actuelle de l'explosion de l'information, le site Web de questions-réponses sur les connaissances est devenu une plate-forme importante permettant aux gens d'acquérir des connaissances et d'échanger des expériences. Pour les développeurs, la mise en œuvre d'une fonction de discussion des questions et d'édition des réponses similaire à Stack Overflow est une tâche très difficile. Cet article explique comment implémenter une telle fonctionnalité à l'aide de PHP et fournit des exemples de code.

  1. Conception et création de bases de données

Tout d'abord, nous devons concevoir et créer une base de données pour stocker les informations sur les questions et réponses. Dans cet exemple, nous allons utiliser une base de données MySQL et créer deux tables : questions et réponses.

CREATE TABLE questions (
    id INT(11) AUTO_INCREMENT PRIMARY KEY,
    title VARCHAR(255) NOT NULL,
    content TEXT,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

CREATE TABLE answers (
    id INT(11) AUTO_INCREMENT PRIMARY KEY,
    question_id INT(11) NOT NULL,
    content TEXT,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
Copier après la connexion

La table des questions est utilisée pour stocker le titre, le contenu et l'heure de création de la question, et la table des réponses est utilisée pour stocker le contenu de la réponse, l'ID de la question et l'heure de création.

  1. Afficher la liste des problèmes et les détails du problème

Ensuite, nous devons écrire du code PHP pour afficher la liste des problèmes et les détails du problème. Tout d’abord, nous créons un fichier appelé index.php qui affichera la liste des questions.

<?php
// 连接数据库
$conn = mysqli_connect("localhost", "username", "password", "database");

// 查询所有问题
$query = "SELECT * FROM questions ORDER BY created_at DESC";
$result = mysqli_query($conn, $query);

// 显示问题列表
while ($row = mysqli_fetch_assoc($result)) {
    echo "<h2><a href='question.php?id={$row['id']}'>{$row['title']}</a></h2>";
    echo "<p>{$row['content']}</p>";
    echo "<hr>";
}
?>
Copier après la connexion

Ensuite, nous créons un fichier appelé question.php qui affiche les détails de la question et les réponses associées.

<?php
// 连接数据库
$conn = mysqli_connect("localhost", "username", "password", "database");

// 获取问题 ID
$id = $_GET['id'];

// 查询问题的详细信息
$query = "SELECT * FROM questions WHERE id = $id";
$result = mysqli_query($conn, $query);
$question = mysqli_fetch_assoc($result);

// 查询问题的答案列表
$query = "SELECT * FROM answers WHERE question_id = $id ORDER BY created_at DESC";
$result = mysqli_query($conn, $query);

// 显示问题和答案
echo "<h1>{$question['title']}</h1>";
echo "<p>{$question['content']}</p>";

while ($row = mysqli_fetch_assoc($result)) {
    echo "<h3>答案</h3>";
    echo "<p>{$row['content']}</p>";
    echo "<hr>";
}
?>
Copier après la connexion
  1. Soumettre des questions et des réponses

Enfin, nous devons écrire du code PHP pour gérer les questions et réponses soumises par les utilisateurs. Créez un fichier appelé submit.php qui gère les questions et réponses soumises par les utilisateurs et les enregistre dans la base de données.

<?php
// 连接数据库
$conn = mysqli_connect("localhost", "username", "password", "database");

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    // 提交问题
    if (isset($_POST['question'])) {
        $title = $_POST['title'];
        $content = $_POST['content'];

        $query = "INSERT INTO questions (title, content) VALUES ('$title', '$content')";
        mysqli_query($conn, $query);
    }

    // 提交答案
    if (isset($_POST['answer'])) {
        $question_id = $_POST['question_id'];
        $content = $_POST['content'];

        $query = "INSERT INTO answers (question_id, content) VALUES ($question_id, '$content')";
        mysqli_query($conn, $query);
    }

    // 重定向到问题详情页面
    header("Location: question.php?id=$question_id");
    exit();
}
?>
Copier après la connexion

Maintenant, nous pouvons afficher la liste de questions en accédant à la page index.php, et afficher les détails et les réponses des questions en accédant à la page question.php. Et, en soumettant un formulaire avec des questions et réponses, les données sont enregistrées dans la base de données.

Résumé

Il n'est pas difficile d'implémenter des fonctions de discussion de questions et d'édition de réponses dans un site Web de questions et réponses de connaissances via PHP. Il nous suffit de créer une base de données pour stocker les informations sur les questions et réponses, et d'écrire du code PHP pour afficher et soumettre les données. Cet article fournit un exemple simple que vous pouvez étendre et améliorer en fonction de vos propres besoins. Je vous souhaite du succès dans la mise en œuvre d’un puissant site Web de questions et réponses sur les connaissances !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal