亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.430618.com 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

如何使用PHP開發簡單的在線問答系統?

在互聯網時代,問答社區已經成為了人們獲取各種知識和解決問題的常見方式。許多網站都提供了問答功能,用戶可以在這些平臺上提出問題并獲得其他用戶的回答。本文將介紹如何使用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開發,并啟發你構建更加完善的在線問答系統。

以上就是如何使用PHP開發簡單的在線問答系統的詳細內容,更多請關注www.92cms.cn其它相關文章!

分享到:
標簽:在線 如何使用 開發 簡單 問答
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定