> 백엔드 개발 > PHP 튜토리얼 > PHP를 사용하여 간단한 온라인 투표 시스템을 개발하는 방법

PHP를 사용하여 간단한 온라인 투표 시스템을 개발하는 방법

WBOY
풀어 주다: 2023-09-24 11:48:01
원래의
1367명이 탐색했습니다.

PHP를 사용하여 간단한 온라인 투표 시스템을 개발하는 방법

PHP를 사용하여 간단한 온라인 투표 시스템을 개발하는 방법

투표는 학교, 회사, 사회를 막론하고 매우 일반적인 활동이며 다양한 투표 활동이 조직되는 경우가 많습니다. 인터넷의 발달로 이제 많은 투표 활동이 온라인으로 이루어질 수 있게 되었습니다. 이 기사에서는 PHP를 사용하여 간단한 온라인 투표 시스템을 개발하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

1. 데이터베이스 설계

먼저 투표 관련 정보를 저장할 데이터베이스를 설계해야 합니다. 투표 주제 테이블(vote_subject)과 투표 옵션 테이블(vote_option)이라는 두 개의 테이블을 디자인해야 한다고 가정해 보겠습니다.

투표 주제 테이블에는 다음 필드가 포함되어야 합니다.

  • 주제 ID(subject_id): 주제의 고유 식별자, 일반적으로 자동 증가하는 정수입니다.
  • Subject_name: 주제의 이름입니다.
  • 생성시간(create_time) : 테마가 생성된 시간입니다.

투표 옵션 테이블에는 다음 필드가 포함되어야 합니다.

  • 옵션 ID(option_id): 옵션의 고유 식별자이며 일반적으로 자동 증가하는 정수입니다.
  • 제목 ID(subject_id): 옵션이 속한 제목 ID입니다.
  • 옵션 이름(option_name): 옵션의 이름입니다.
  • 옵션 투표(option_count): 해당 옵션에 대한 현재 투표 수입니다.

2. 투표 주제 만들기

먼저 사용자가 새로운 투표 주제를 만들 수 있는 페이지를 만들어야 합니다. 이 페이지에서 사용자는 주제 이름을 입력하고 양식을 제출할 수 있습니다.

샘플 코드:

<!DOCTYPE html>
<html>
<head>
    <title>创建投票主题</title>
</head>
<body>
    <h1>创建投票主题</h1>
    <form action="create_subject.php" method="post">
        <label for="subject_name">主题名称:</label>
        <input type="text" name="subject_name" id="subject_name" required>
        <br><br>
        <input type="submit" value="创建">
    </form>
</body>
</html>
로그인 후 복사

create_subject.php 파일에서 사용자가 제출한 양식 데이터를 받은 후 투표 주제 테이블에 주제 이름을 삽입하고 새 주제 ID를 생성할 수 있습니다.

샘플 코드:

<?php
// 连接数据库
$servername = "localhost";
$username = "root";
$password = "123456";
$dbname = "vote_system";
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("连接数据库失败:" . $conn->connect_error);
}

// 接收用户提交的表单数据
$subject_name = $_POST['subject_name'];

// 将主题名称插入投票主题表
$sql = "INSERT INTO vote_subject (subject_name, create_time) VALUES ('$subject_name', NOW())";
if ($conn->query($sql) === TRUE) {
    $subject_id = $conn->insert_id;  // 获取新的主题ID
    echo "创建投票主题成功,主题ID为:" . $subject_id;
} else {
    echo "创建投票主题失败:" . $conn->error;
}

// 关闭数据库连接
$conn->close();
?>
로그인 후 복사

3. 투표 옵션 추가

다음으로 투표 옵션을 추가할 페이지를 만들어야 합니다. 이 페이지에서 사용자는 옵션 이름을 입력하고 해당 옵션이 속한 주제를 선택해야 합니다.

샘플 코드:

<!DOCTYPE html>
<html>
<head>
    <title>添加投票选项</title>
</head>
<body>
    <h1>添加投票选项</h1>
    <form action="add_option.php" method="post">
        <label for="option_name">选项名称:</label>
        <input type="text" name="option_name" id="option_name" required>
        <br><br>
        <label for="subject_id">所属主题:</label>
        <select name="subject_id" id="subject_id">
            <?php
            // 查询所有的投票主题
            $sql = "SELECT * FROM vote_subject";
            $result = $conn->query($sql);
            if ($result->num_rows > 0) {
                while ($row = $result->fetch_assoc()) {
                    echo "<option value=" . $row['subject_id'] . ">" . $row['subject_name'] . "</option>";
                }
            }
            ?>
        </select>
        <br><br>
        <input type="submit" value="添加">
    </form>
</body>
</html>
로그인 후 복사

add_option.php 파일에서 사용자가 제출한 양식 데이터를 받은 다음 옵션 이름과 해당 옵션이 속한 주제를 투표 옵션 테이블에 삽입할 수 있습니다.

샘플 코드:

<?php
// 连接数据库(同上)

// 接收用户提交的表单数据
$option_name = $_POST['option_name'];
$subject_id = $_POST['subject_id'];

// 将选项名称和所属主题插入投票选项表
$sql = "INSERT INTO vote_option (subject_id, option_name, option_count) VALUES ('$subject_id', '$option_name', 0)";
if ($conn->query($sql) === TRUE) {
    echo "添加投票选项成功";
} else {
    echo "添加投票选项失败:" . $conn->error;
}

// 关闭数据库连接(同上)
?>
로그인 후 복사

4. 투표 작업

마지막으로 사용자가 투표할 수 있는 페이지를 만들어야 합니다. 이 페이지에서 사용자는 주제를 선택한 다음 투표할 옵션을 선택할 수 있습니다.

샘플 코드:

<!DOCTYPE html>
<html>
<head>
    <title>进行投票</title>
</head>
<body>
    <h1>进行投票</h1>
    <form action="vote.php" method="post">
        <label for="subject_id">选择主题:</label>
        <select name="subject_id" id="subject_id">
            <?php
            // 查询所有的投票主题
            $sql = "SELECT * FROM vote_subject";
            $result = $conn->query($sql);
            if ($result->num_rows > 0) {
                while ($row = $result->fetch_assoc()) {
                    echo "<option value=" . $row['subject_id'] . ">" . $row['subject_name'] . "</option>";
                }
            }
            ?>
        </select>
        <br><br>
        <label for="option_id">选择选项:</label>
        <select name="option_id" id="option_id">
            <?php
            // 查询指定主题下的所有选项
            $subject_id = $_POST['subject_id'];
            $sql = "SELECT * FROM vote_option WHERE subject_id = $subject_id";
            $result = $conn->query($sql);
            if ($result->num_rows > 0) {
                while ($row = $result->fetch_assoc()) {
                    echo "<option value=" . $row['option_id'] . ">" . $row['option_name'] . "</option>";
                }
            }
            ?>
        </select>
        <br><br>
        <input type="submit" value="投票">
    </form>
</body>
</html>
로그인 후 복사

vote.php 파일에서 사용자가 제출한 양식 데이터를 받은 다음 선택한 테마와 옵션을 기반으로 옵션 투표를 업데이트할 수 있습니다.

샘플 코드:

<?php
// 连接数据库(同上)

// 接收用户提交的表单数据
$subject_id = $_POST['subject_id'];
$option_id = $_POST['option_id'];

// 更新选项票数
$sql = "UPDATE vote_option SET option_count = option_count + 1 WHERE option_id = $option_id";
if ($conn->query($sql) === TRUE) {
    echo "投票成功";
} else {
    echo "投票失败:" . $conn->error;
}

// 关闭数据库连接(同上)
?>
로그인 후 복사

5. 요약

위 단계를 거쳐 간단한 온라인 투표 시스템을 구현했습니다. 사용자는 투표 주제 생성, 투표 옵션 추가, 투표 작업 수행을 통해 전체 투표 프로세스를 완료할 수 있습니다. 물론, 위의 코드는 예시일 뿐이며, 실제 개발을 위해서는 더 많은 기능과 보안을 고려해야 할 수도 있습니다.

이 글이 PHP를 처음 접하는 개발자들에게 도움이 되길 바라며, 더욱 흥미롭고 실용적인 투표 시스템을 개발해보시길 바랍니다!

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

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