如何使用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其它相關文章!






