Heim  >  Artikel  >  Backend-Entwicklung  >  Wie man mit PHP ein einfaches Online-Frage- und Antwortsystem entwickelt

Wie man mit PHP ein einfaches Online-Frage- und Antwortsystem entwickelt

WBOY
WBOYOriginal
2023-09-21 16:28:49787Durchsuche

Wie man mit PHP ein einfaches Online-Frage- und Antwortsystem entwickelt

Wie entwickelt man mit PHP ein einfaches Online-Frage- und Antwortsystem?

Im Internetzeitalter sind Q&A-Communitys für Menschen zu einer gängigen Möglichkeit geworden, sich vielfältiges Wissen anzueignen und Probleme zu lösen. Viele Websites bieten Q&A-Funktionen an, mit denen Benutzer Fragen stellen und Antworten von anderen Benutzern erhalten können. In diesem Artikel wird erläutert, wie Sie mit PHP ein einfaches Online-Frage- und Antwortsystem entwickeln und spezifische Codebeispiele bereitstellen.

Zuerst müssen wir eine Datenbank erstellen, um Fragen und Antworten zu speichern. Dies kann mithilfe von MySQL oder anderen relationalen Datenbanken erreicht werden. Nachfolgend finden Sie eine Beispiel-SQL-Anweisung zum Erstellen einer Fragentabelle und einer Antworttabelle.

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

CREATE TABLE answers (
    id INT AUTO_INCREMENT PRIMARY KEY,
    question_id INT NOT NULL,
    content TEXT NOT NULL,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY (question_id) REFERENCES questions(id)
);

Als nächstes müssen wir eine PHP-Datei erstellen, um das Hinzufügen, Löschen, Ändern und Überprüfen von Fragen und Antworten zu verwalten. Hier ist ein einfacher Beispielcode:

<?php
// 连接数据库
$host = 'localhost';
$db = 'question_answer';
$user = 'root';
$password = 'password';
$conn = new PDO("mysql:host=$host;dbname=$db", $user, $password);

// 添加问题
if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['title']) && isset($_POST['content'])) {
    $title = $_POST['title'];
    $content = $_POST['content'];

    $sql = "INSERT INTO questions (title, content) VALUES (?, ?)";
    $stmt = $conn->prepare($sql);
    $stmt->execute([$title, $content]);
    $questionId = $conn->lastInsertId();

    // 返回问题ID
    echo json_encode(['questionId' => $questionId]);
    exit;
}

// 获取问题和答案
if ($_SERVER['REQUEST_METHOD'] === 'GET' && isset($_GET['questionId'])) {
    $questionId = $_GET['questionId'];

    // 获取问题
    $sql = "SELECT * FROM questions WHERE id = ?";
    $stmt = $conn->prepare($sql);
    $stmt->execute([$questionId]);
    $question = $stmt->fetch(PDO::FETCH_ASSOC);

    // 获取答案
    $sql = "SELECT * FROM answers WHERE question_id = ?";
    $stmt = $conn->prepare($sql);
    $stmt->execute([$questionId]);
    $answers = $stmt->fetchAll(PDO::FETCH_ASSOC);

    // 返回问题和答案
    echo json_encode(['question' => $question, 'answers' => $answers]);
    exit;
}

// 添加答案
if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['questionId']) && isset($_POST['content'])) {
    $questionId = $_POST['questionId'];
    $content = $_POST['content'];

    $sql = "INSERT INTO answers (question_id, content) VALUES (?, ?)";
    $stmt = $conn->prepare($sql);
    $stmt->execute([$questionId, $content]);

    // 返回成功
    echo json_encode(['success' => true]);
    exit;
}

// 删除问题
if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['deleteQuestionId'])) {
    $questionId = $_POST['deleteQuestionId'];

    // 删除问题
    $sql = "DELETE FROM questions WHERE id = ?";
    $stmt = $conn->prepare($sql);
    $stmt->execute([$questionId]);

    // 删除相关答案
    $sql = "DELETE FROM answers WHERE question_id = ?";
    $stmt = $conn->prepare($sql);
    $stmt->execute([$questionId]);

    // 返回成功
    echo json_encode(['success' => true]);
    exit;
}
?>

Im obigen Code verwenden wir PDO, um eine Verbindung zur Datenbank herzustellen, und verwenden vorbereitete Anweisungen, um SQL-Injection-Angriffe zu verhindern.

Als nächstes können wir eine Frontend-Seite erstellen, um Fragen und Antworten anzuzeigen und Funktionen zum Hinzufügen und Löschen von Fragen bereitzustellen. Das Folgende ist ein einfaches Beispiel für eine Front-End-Seite:

<!DOCTYPE html>
<html>
<head>
    <title>在线问答系统</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
</head>
<body>
    <h1>在线问答系统</h1>

    <!-- 添加问题表单 -->
    <form id="addQuestionForm">
        <input type="text" name="title" placeholder="问题标题" required>
        <textarea name="content" placeholder="问题内容" required></textarea>
        <button type="submit">添加问题</button>
    </form>

    <!-- 问题列表 -->
    <ul id="questionList"></ul>

    <script>
        // 添加问题
        $('#addQuestionForm').submit(function(e) {
            e.preventDefault();

            $.post('qa.php', $(this).serialize(), function(response) {
                // 更新问题列表
                fetchQuestionList();
                // 清空表单
                $('#addQuestionForm')[0].reset();
            }, 'json');
        });

        // 获取问题列表
        function fetchQuestionList() {
            $.get('qa.php', function(response) {
                var questionList = '';
                for (var i = 0; i < response.length; i++) {
                    var question = response[i];
                    var questionItem = '<li>'
                        + '<h3>' + question.title + '</h3>'
                        + '<p>' + question.content + '</p>'
                        + '<button onclick="deleteQuestion(' + question.id + ')">删除</button>'
                        + '</li>';

                    questionList += questionItem;
                }

                $('#questionList').html(questionList);
            }, 'json');
        }

        // 删除问题
        function deleteQuestion(questionId) {
            if (confirm('确定要删除该问题及相关答案吗?')) {
                $.post('qa.php', { deleteQuestionId: questionId }, function(response) {
                    fetchQuestionList();
                }, 'json');
            }
        }

        // 页面加载时获取问题列表
        $(function() {
            fetchQuestionList();
        });
    </script>
</body>
</html>

Im obigen Code verwenden wir jQuery, um AJAX-Anfragen für die Kommunikation mit dem Server zu senden, und verwenden DOM-Operationen, um den Seiteninhalt dynamisch zu aktualisieren.

Zusammenfassend können wir anhand der oben genannten PHP- und HTML-Codebeispiele ein einfaches Online-Frage- und Antwortsystem implementieren. Dies ist natürlich nur ein einfaches Beispiel. Das eigentliche Frage- und Antwortsystem muss auch weitere Funktions- und Sicherheitsaspekte berücksichtigen. Ich hoffe, dieser Artikel kann Ihnen den Einstieg in die PHP-Entwicklung erleichtern und Sie dazu inspirieren, ein umfassenderes Online-Frage- und Antwortsystem zu erstellen.

Das obige ist der detaillierte Inhalt vonWie man mit PHP ein einfaches Online-Frage- und Antwortsystem entwickelt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn