> 백엔드 개발 > PHP 튜토리얼 > PHP를 사용하여 간단한 온라인 질문 및 답변 시스템을 구현하는 방법

PHP를 사용하여 간단한 온라인 질문 및 답변 시스템을 구현하는 방법

PHPz
풀어 주다: 2023-09-26 09:54:01
원래의
1511명이 탐색했습니다.

PHP를 사용하여 간단한 온라인 질문 및 답변 시스템을 구현하는 방법

PHP를 사용하여 간단한 온라인 Q&A 시스템을 구현하는 방법

소개:

인터넷이 발전하면서 점점 더 많은 사람들이 정보를 얻고 문제를 해결하기 위해 인터넷에 의존하기 시작했습니다. 온라인 Q&A 및 Q&A 시스템은 사용자가 질문하고 답변을 얻는 데 매우 중요한 도구가 되었습니다. 이 기사에서는 PHP 언어를 사용하여 간단한 온라인 질문 및 답변 시스템을 구현하는 방법을 배웁니다. 질문을 보고 질문할 수 있을 뿐만 아니라, 질문에 답변하고 다른 사용자와 소통할 수도 있습니다.

1부: 데이터베이스 구조 설계

시작하기 전에 사용자, 질문 및 답변 정보를 저장할 데이터베이스를 설계해야 합니다. MySQL을 데이터베이스 관리 시스템으로 사용할 수 있습니다.

먼저 "qa_system"이라는 데이터베이스를 만듭니다. 그런 다음 사용자, 질문 및 답변 정보를 저장하기 위해 세 개의 테이블을 만들어야 합니다. 다음은 이 테이블의 디자인입니다:

Users 테이블(사용자):

  • id: int(기본 키)
  • username: varchar(50)
  • password: varchar(50)

질문 테이블(질문 ):

  • id: int (기본 키)
  • user_id: int (외부 키, 사용자 테이블의 id 필드에 해당)
  • title: varchar(255)
  • content: text
  • created_at: datetime
  • updated_at: datetime

정답 테이블(답변):

  • id: int(기본 키)
  • question_id: int(외래 키, 질문 테이블의 id 필드에 해당)
  • user_id: int(외래 키) , 사용자 테이블의 id 필드에 해당)
  • content : text
  • created_at: datetime
  • updated_at: datetime

위 테이블 디자인을 사용하면 사용자 정보, 질문 및 답변을 쉽게 저장할 수 있습니다.

2부: PHP 코드 작성

  1. 홈페이지 만들기(index.php):

먼저 최신 질문 목록과 로그인/등록 옵션을 표시하는 홈페이지를 만듭니다.

<?php
// index.php

// 连接数据库
$conn = mysqli_connect("localhost", "username", "password", "qa_system");

// 查询最新的问题列表
$query = "SELECT * FROM questions ORDER BY created_at DESC";
$result = mysqli_query($conn, $query);

?>

<!DOCTYPE html>
<html>
<head>
    <title>在线问答系统</title>
</head>
<body>
    <h1>在线问答系统</h1>

    <h2>最新的问题:</h2>
    <?php while ($row = mysqli_fetch_assoc($result)) { ?>
        <h3><?php echo $row['title']; ?></h3>
        <p><?php echo $row['content']; ?></p>
    <?php } ?>

    <h2>登录/注册</h2>
    <form action="login.php" method="POST">
        <input type="text" name="username" placeholder="用户名">
        <input type="password" name="password" placeholder="密码">
        <input type="submit" value="登录">
    </form>
    
    <form action="register.php" method="POST">
        <input type="text" name="username" placeholder="用户名">
        <input type="password" name="password" placeholder="密码">
        <input type="submit" value="注册">
    </form>
</body>
</html>
로그인 후 복사
  1. 로그인 페이지(login.php) 만들기:

사용자가 사용자 이름과 비밀번호를 입력하고 로그인을 클릭하면 해당 사용자가 데이터베이스에 존재하는지 확인하고 존재하는 경우 문제 페이지로 이동합니다.

<?php
// login.php

if ($_SERVER["REQUEST_METHOD"] == "POST") {
    // 获取用户提交的数据
    $username = $_POST["username"];
    $password = $_POST["password"];

    // 连接数据库
    $conn = mysqli_connect("localhost", "username", "password", "qa_system");

    // 查询用户信息
    $query = "SELECT * FROM users WHERE username = '$username' AND password = '$password'";
    $result = mysqli_query($conn, $query);

    // 检查用户是否存在
    if (mysqli_num_rows($result) > 0) {
        // 用户存在,将其用户信息存储到会话中并跳转到问题页面
        $user = mysqli_fetch_assoc($result);
        session_start();
        $_SESSION["user_id"] = $user["id"];
        header("Location: questions.php");
    } else {
        // 用户不存在,显示错误信息
        echo "用户名或密码错误";
    }
}
?>

<!DOCTYPE html>
<html>
<head>
    <title>用户登录</title>
</head>
<body>
    <h1>用户登录</h1>

    <form action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]); ?>" method="POST">
        <input type="text" name="username" placeholder="用户名">
        <input type="password" name="password" placeholder="密码">
        <input type="submit" value="登录">
    </form>
</body>
</html>
로그인 후 복사
  1. 등록 페이지 만들기(register.php):

사용자가 사용자 이름과 비밀번호를 입력하고 등록을 클릭하면 새 사용자를 데이터베이스에 삽입하고 질문 페이지로 이동합니다.

<?php
// register.php

if ($_SERVER["REQUEST_METHOD"] == "POST") {
    // 获取用户提交的数据
    $username = $_POST["username"];
    $password = $_POST["password"];

    // 连接数据库
    $conn = mysqli_connect("localhost", "username", "password", "qa_system");

    // 插入新用户
    $query = "INSERT INTO users (username, password) VALUES ('$username', '$password')";
    mysqli_query($conn, $query);

    // 跳转到问题页面
    header("Location: questions.php");
}
?>

<!DOCTYPE html>
<html>
<head>
    <title>用户注册</title>
</head>
<body>
    <h1>用户注册</h1>

    <form action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]); ?>" method="POST">
        <input type="text" name="username" placeholder="用户名">
        <input type="password" name="password" placeholder="密码">
        <input type="submit" value="注册">
    </form>
</body>
</html>
로그인 후 복사
  1. 질문 만들기 페이지(questions.php):

이 페이지에는 질문의 세부정보와 모든 답변이 표시됩니다. 사용자는 질문에 답하고 다른 사용자와 소통할 수 있습니다.

<?php
// questions.php

// 连接数据库
$conn = mysqli_connect("localhost", "username", "password", "qa_system");

// 获取问题的ID
$question_id = $_GET["id"];

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

// 查询问题的回答列表
$query = "SELECT * FROM answers WHERE question_id = $question_id";
$answers_result = mysqli_query($conn, $query);

?>

<!DOCTYPE html>
<html>
<head>
    <title><?php echo $question["title"]; ?></title>
</head>
<body>
    <h1><?php echo $question["title"]; ?></h1>
    <p><?php echo $question["content"]; ?></p>

    <h2>回答:</h2>
    <?php while ($row = mysqli_fetch_assoc($answers_result)) { ?>
        <p><?php echo $row["content"]; ?></p>
    <?php } ?>

    <h2>我要回答:</h2>
    <?php
        session_start();
        $user_id = $_SESSION["user_id"];
    ?>
    <form action="answer.php" method="POST">
        <input type="hidden" name="question_id" value="<?php echo $question_id; ?>">
        <input type="hidden" name="user_id" value="<?php echo $user_id; ?>">
        <textarea name="content" rows="4" cols="50" placeholder="请输入您的答案"></textarea>
        <input type="submit" value="提交">
    </form>
</body>
</html>
로그인 후 복사
  1. 답변 페이지 만들기(answer.php):

사용자가 답변을 작성하고 제출하면 데이터베이스에 답변이 삽입되고 질문 페이지가 새로 고쳐집니다.

<?php
// answer.php

if ($_SERVER["REQUEST_METHOD"] == "POST") {
    // 获取用户提交的数据
    $question_id = $_POST["question_id"];
    $user_id = $_POST["user_id"];
    $content = $_POST["content"];

    // 连接数据库
    $conn = mysqli_connect("localhost", "username", "password", "qa_system");

    // 插入新答案
    $query = "INSERT INTO answers (question_id, user_id, content) VALUES ($question_id, $user_id, '$content')";
    mysqli_query($conn, $query);

    // 跳转回问题页面
    header("Location: questions.php?id=$question_id");
}
?>
로그인 후 복사

요약:

위 단계를 통해 간단한 온라인 Q&A 시스템을 성공적으로 만들었습니다. 사용자는 등록, 로그인 및 질문을 할 수 있습니다. 다른 사용자가 질문을 보고 답변할 수 있습니다. 이는 단지 기본적인 구현일 뿐이므로 필요에 따라 더 많은 기능과 사용자 경험을 추가할 수 있습니다. 이 글이 여러분에게 도움이 되기를 바라며, PHP 질문 및 답변 시스템을 성공적으로 작성하시기를 바랍니다!

위 내용은 PHP를 사용하여 간단한 온라인 질문 및 답변 시스템을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿