当前位置:首页 > PHP

php实现网页投票

2026-03-13 04:59:06PHP

php实现网页投票

PHP 网页投票系统实现

创建一个简单的网页投票系统需要处理用户投票、数据存储和结果显示。以下是关键实现步骤:

php实现网页投票

数据库设计

创建用于存储投票选项和结果的表:

CREATE TABLE vote_options (
    id INT AUTO_INCREMENT PRIMARY KEY,
    option_name VARCHAR(255) NOT NULL
);

CREATE TABLE vote_results (
    id INT AUTO_INCREMENT PRIMARY KEY,
    option_id INT,
    vote_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY (option_id) REFERENCES vote_options(id)
);

投票表单页面(vote_form.php)

<?php
// 连接数据库
$db = new PDO('mysql:host=localhost;dbname=vote_system', 'username', 'password');

// 获取投票选项
$options = $db->query("SELECT * FROM vote_options")->fetchAll(PDO::FETCH_ASSOC);
?>

<form action="process_vote.php" method="post">
    <?php foreach ($options as $option): ?>
        <label>
            <input type="radio" name="vote" value="<?= $option['id'] ?>">
            <?= htmlspecialchars($option['option_name']) ?>
        </label><br>
    <?php endforeach; ?>
    <button type="submit">投票</button>
</form>

处理投票(process_vote.php)

<?php
session_start();
$db = new PDO('mysql:host=localhost;dbname=vote_system', 'username', 'password');

// 防止重复投票
if (isset($_SESSION['voted'])) {
    die('您已经投过票了');
}

if (isset($_POST['vote'])) {
    $optionId = (int)$_POST['vote'];

    // 验证选项是否存在
    $stmt = $db->prepare("SELECT id FROM vote_options WHERE id = ?");
    $stmt->execute([$optionId]);

    if ($stmt->fetch()) {
        // 记录投票
        $db->prepare("INSERT INTO vote_results (option_id) VALUES (?)")
           ->execute([$optionId]);

        $_SESSION['voted'] = true;
        header('Location: results.php');
        exit;
    }
}

header('Location: vote_form.php');

显示结果(results.php)

<?php
$db = new PDO('mysql:host=localhost;dbname=vote_system', 'username', 'password');

// 获取投票统计
$results = $db->query("
    SELECT o.option_name, COUNT(r.id) as vote_count 
    FROM vote_options o 
    LEFT JOIN vote_results r ON o.id = r.option_id 
    GROUP BY o.id
")->fetchAll(PDO::FETCH_ASSOC);

// 计算总票数
$total = array_sum(array_column($results, 'vote_count'));
?>

<h3>投票结果</h3>
<?php foreach ($results as $result): ?>
    <div>
        <?= htmlspecialchars($result['option_name']) ?>: 
        <?= $result['vote_count'] ?> 票 
        (<?= $total > 0 ? round($result['vote_count'] / $total * 100, 2) : 0 ?>%)
    </div>
<?php endforeach; ?>

安全增强措施

  1. 使用预处理语句防止SQL注入
  2. 对输出内容使用htmlspecialchars()防止XSS攻击
  3. 通过会话控制防止重复投票
  4. 验证用户输入的投票选项是否存在

可选扩展功能

  1. 添加IP限制防止多账号投票
  2. 实现图形化结果展示(使用Chart.js等库)
  3. 添加投票截止时间功能
  4. 实现多语言支持
  5. 添加管理员界面管理投票选项

这个基础实现可以根据具体需求进行扩展和定制。

标签: 网页php
分享给朋友:

相关文章

php实现栈

php实现栈

栈的基本概念 栈(Stack)是一种遵循后进先出(LIFO)原则的数据结构。核心操作包括: push:元素入栈。 pop:元素出栈(返回并移除栈顶元素)。 peek:查看栈顶元素(不移除…

php实现异步

php实现异步

PHP 实现异步的方法 PHP 本身是同步执行的脚本语言,但可以通过以下方法模拟异步操作或实现异步效果: 使用多进程(pcntl_fork) 通过 pcntl_fork 创建子进程实现异步,适用于…

php 实现验证码

php 实现验证码

使用 PHP 生成验证码 验证码(CAPTCHA)用于防止自动化脚本提交表单,以下是几种常见的 PHP 实现方法。 使用 GD 库生成图片验证码 GD 库是 PHP 的图像处理扩展,可用于生成验证码…

php队列的实现

php队列的实现

PHP队列的实现方式 PHP中实现队列功能可以通过多种方式,根据需求选择适合的方案: 使用数组实现基础队列 PHP数组本身支持队列操作,利用array_push和array_shift函数: $q…

php无限分类的实现

php无限分类的实现

PHP无限分类的实现 无限分类是一种常见的树形结构数据组织方式,适用于商品分类、菜单管理、地区选择等场景。以下是几种实现方法: 递归实现法 递归是最直观的实现方式,通过函数自身调用来遍历子分类。数据…

php 实现跳转

php 实现跳转

PHP 实现页面跳转的方法 在PHP中,实现页面跳转可以通过多种方式完成,以下是几种常用的方法: 使用header函数 header函数是PHP中最常用的跳转方法,通过发送HTTP头部信息实现跳转。…