
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. 투표 주제 만들기
먼저 사용자가 새로운 투표 주제를 만들 수 있는 페이지를 만들어야 합니다. 이 페이지에서 사용자는 주제 이름을 입력하고 양식을 제출할 수 있습니다.
샘플 코드:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <!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를 생성할 수 있습니다.
샘플 코드:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | <?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;
echo "创建投票主题成功,主题ID为:" . $subject_id ;
} else {
echo "创建投票主题失败:" . $conn ->error;
}
$conn ->close();
?>
|
로그인 후 복사
3. 투표 옵션 추가
다음으로 투표 옵션을 추가할 페이지를 만들어야 합니다. 이 페이지에서 사용자는 옵션 이름을 입력하고 해당 옵션이 속한 주제를 선택해야 합니다.
샘플 코드:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | <!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 파일에서 사용자가 제출한 양식 데이터를 받은 다음 옵션 이름과 해당 옵션이 속한 주제를 투표 옵션 테이블에 삽입할 수 있습니다.
샘플 코드:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | <?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. 투표 작업
마지막으로 사용자가 투표할 수 있는 페이지를 만들어야 합니다. 이 페이지에서 사용자는 주제를 선택한 다음 투표할 옵션을 선택할 수 있습니다.
샘플 코드:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | <!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 파일에서 사용자가 제출한 양식 데이터를 받은 다음 선택한 테마와 옵션을 기반으로 옵션 투표를 업데이트할 수 있습니다.
샘플 코드:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | <?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 중국어 웹사이트의 기타 관련 기사를 참조하세요!