ホームページ  >  記事  >  バックエンド開発  >  PHP を使用して簡単なオンライン質疑応答システムを開発する方法

PHP を使用して簡単なオンライン質疑応答システムを開発する方法

WBOY
WBOYオリジナル
2023-09-21 16:28:49860ブラウズ

PHP を使用して簡単なオンライン質疑応答システムを開発する方法

PHP を使用して簡単なオンライン質疑応答システムを開発するにはどうすればよいですか?

インターネット時代において、Q&A コミュニティは人々がさまざまな知識を取得し、問題を解決するための一般的な手段になりました。多くの Web サイトには、ユーザーが質問して他のユーザーから回答を得ることができる Q&A 機能が提供されています。この記事では、PHP を使用して簡単なオンライン質疑応答システムを開発する方法と、具体的なコード例を紹介します。

まず、質問と回答を保存するデータベースを作成する必要があります。これは、MySQL またはその他のリレーショナル データベースを使用して実現できます。以下は、質問テーブルと回答テーブルを作成する SQL ステートメントの例です。

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)
);

次に、質問と回答の追加、削除、変更、確認を処理するための PHP ファイルを作成する必要があります。以下は簡単なサンプル コードです。

<?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;
}
?>

上記のコードでは、PDO を使用してデータベースに接続し、プリペアド ステートメントを使用して SQL インジェクション攻撃を防ぎます。

次に、質問と回答を表示するフロントエンド ページを作成し、質問を追加および削除する機能を提供します。以下は簡単なフロントエンド ページの例です。

<!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>

上記のコードでは、jQuery を使用して AJAX リクエストを送信してサーバーと通信し、DOM 操作を使用してページ コンテンツを動的に更新します。

要約すると、上記の PHP と HTML コードの例を通じて、簡単なオンライン質問と回答システムを実装できます。もちろん、これは基本的な例にすぎず、実際の質疑応答システムでは、さらに機能やセキュリティの問題も考慮する必要があります。この記事が、PHP 開発を始めるのに役立ち、より完全なオンライン Q&A システムを構築するきっかけになれば幸いです。

以上がPHP を使用して簡単なオンライン質疑応答システムを開発する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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