当前位置:首页 > PHP

php 实现投票功能

2026-02-15 06:18:54PHP

实现投票功能的基本步骤

数据库设计
创建数据表存储投票选项和投票记录。常见的表结构包括:

  • polls 表:存储投票主题(id, title, description, created_at
  • poll_options 表:存储选项(id, poll_id, option_text, vote_count
  • poll_votes 表:记录用户投票(id, poll_id, option_id, user_id, voted_at

SQL 示例

php 实现投票功能

CREATE TABLE polls (
    id INT AUTO_INCREMENT PRIMARY KEY,
    title VARCHAR(255) NOT NULL,
    description TEXT,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

CREATE TABLE poll_options (
    id INT AUTO_INCREMENT PRIMARY KEY,
    poll_id INT NOT NULL,
    option_text VARCHAR(255) NOT NULL,
    vote_count INT DEFAULT 0,
    FOREIGN KEY (poll_id) REFERENCES polls(id)
);

CREATE TABLE poll_votes (
    id INT AUTO_INCREMENT PRIMARY KEY,
    poll_id INT NOT NULL,
    option_id INT NOT NULL,
    user_id INT,
    voted_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY (poll_id) REFERENCES polls(id),
    FOREIGN KEY (option_id) REFERENCES poll_options(id)
);

前端表单提交

创建投票表单,用户可选择选项并提交:

php 实现投票功能

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

后端处理逻辑

vote.php 中处理投票请求:

<?php
session_start();
require 'db_connection.php'; // 数据库连接文件

if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['option_id'])) {
    $option_id = intval($_POST['option_id']);
    $user_id = isset($_SESSION['user_id']) ? $_SESSION['user_id'] : null;

    // 检查用户是否已投票(如需限制)
    if ($user_id) {
        $stmt = $pdo->prepare("SELECT id FROM poll_votes WHERE poll_id = (SELECT poll_id FROM poll_options WHERE id = ?) AND user_id = ?");
        $stmt->execute([$option_id, $user_id]);
        if ($stmt->fetch()) {
            die("您已参与过本次投票");
        }
    }

    // 更新投票数
    $pdo->beginTransaction();
    try {
        $pdo->prepare("UPDATE poll_options SET vote_count = vote_count + 1 WHERE id = ?")->execute([$option_id]);
        $pdo->prepare("INSERT INTO poll_votes (poll_id, option_id, user_id) VALUES ((SELECT poll_id FROM poll_options WHERE id = ?), ?, ?)")
            ->execute([$option_id, $option_id, $user_id]);
        $pdo->commit();
        header("Location: results.php?poll_id=" . $pdo->lastInsertId());
    } catch (Exception $e) {
        $pdo->rollBack();
        die("投票失败: " . $e->getMessage());
    }
}
?>

结果显示页面

results.php 中展示投票结果:

<?php
$poll_id = intval($_GET['poll_id']);
$stmt = $pdo->prepare("SELECT title FROM polls WHERE id = ?");
$stmt->execute([$poll_id]);
$poll = $stmt->fetch();

$options = $pdo->query("SELECT option_text, vote_count FROM poll_options WHERE poll_id = $poll_id")->fetchAll();
$total_votes = array_sum(array_column($options, 'vote_count'));
?>

<h3><?php echo htmlspecialchars($poll['title']); ?></h3>
<ul>
    <?php foreach ($options as $option): ?>
        <li>
            <?php echo htmlspecialchars($option['option_text']); ?>:
            <?php echo $option['vote_count']; ?> 票
            (<?php echo $total_votes > 0 ? round($option['vote_count'] / $total_votes * 100, 2) : 0; ?>%)
        </li>
    <?php endforeach; ?>
</ul>

安全注意事项

  • 使用 htmlspecialchars() 防止 XSS 攻击
  • 通过 intval() 或参数化查询防止 SQL 注入
  • 对用户身份进行验证(如需要登录投票)
  • 使用事务确保数据一致性

扩展功能建议

  • 添加 IP 限制或 Cookie 验证防止刷票
  • 实现多选投票(需修改表单和数据处理逻辑)
  • 增加图表可视化(如使用 Chart.js)
  • 设置投票截止时间(在 polls 表中添加 end_time 字段)

标签: 功能php
分享给朋友:

相关文章

vue实现名字查找功能

vue实现名字查找功能

实现名字查找功能 在Vue中实现名字查找功能,可以通过多种方式完成。以下是几种常见的实现方法: 使用v-model和computed属性 创建一个输入框,使用v-model绑定输入的值,通过comp…

vue实现功能插件

vue实现功能插件

Vue 功能插件实现方法 插件基本结构 Vue 插件通常需要暴露一个 install 方法,该方法接收 Vue 构造函数作为参数。基本结构如下: const MyPlugin = { insta…

php实现分类

php实现分类

PHP实现分类的方法 数据库设计 创建分类表时,通常需要包含id、名称、父级id等字段。父级id用于实现多级分类结构。 CREATE TABLE categories ( id INT AU…

php实现即时通讯

php实现即时通讯

PHP 实现即时通讯的方案 即时通讯(IM)可以通过多种方式实现,PHP 作为服务器端语言,通常需要结合前端技术(如 WebSocket、AJAX)或第三方服务来实现实时通信。以下是几种常见的实现方式…

php无限分类的实现

php无限分类的实现

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

php 实现无限分类

php 实现无限分类

无限分类的实现方法 无限分类通常用于构建多层级结构的数据,如商品分类、菜单管理等。以下是几种常见的实现方式: 邻接列表模型(Adjacency List) 这是最简单的实现方式,每个分类记录存储其父…