PHP를 사용하여 간단한 온라인 투표 시스템을 개발하는 방법
투표는 학교, 회사, 사회를 막론하고 매우 일반적인 활동이며 다양한 투표 활동이 조직되는 경우가 많습니다. 인터넷의 발달로 이제 많은 투표 활동이 온라인으로 이루어질 수 있게 되었습니다. 이 기사에서는 PHP를 사용하여 간단한 온라인 투표 시스템을 개발하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.
1. 데이터베이스 설계
먼저 투표 관련 정보를 저장할 데이터베이스를 설계해야 합니다. 투표 주제 테이블(vote_subject)과 투표 옵션 테이블(vote_option)이라는 두 개의 테이블을 디자인해야 한다고 가정해 보겠습니다.
투표 주제 테이블에는 다음 필드가 포함되어야 합니다.
투표 옵션 테이블에는 다음 필드가 포함되어야 합니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!