当前位置:首页 > 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 示例

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)
);

前端表单提交

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

<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 实现投票功能

<?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绑定用户选择的答案数组,结合v-for循环渲染选项列表。示例代码: <template> <div>…

php实现留言板功能

php实现留言板功能

PHP 留言板功能实现 数据库设计 创建数据库表 messages,包含以下字段: id:自增主键 name:留言者姓名(VARCHAR) email:留言者邮箱(VARCHAR) content:…

vue电影功能实现

vue电影功能实现

Vue 电影功能实现 数据获取与展示 使用 Axios 或 Fetch API 从电影 API(如 TMDb、豆瓣 API)获取数据。在 Vue 的 created 或 mounted 生命周期钩子中…

php实现接口

php实现接口

PHP 实现接口的方法 在 PHP 中,接口(Interface)用于定义一组方法的规范,而不实现具体功能。类可以实现一个或多个接口,并必须实现接口中定义的所有方法。 定义接口 接口使用 inter…

php搜索功能实现的

php搜索功能实现的

PHP 搜索功能实现方法 数据库搜索实现 使用 SQL 的 LIKE 语句进行模糊匹配,适用于小型网站和简单搜索需求。 $searchTerm = $_GET['search']; $query =…

php 实现单链表

php 实现单链表

单链表的基本概念 单链表是一种线性数据结构,由节点组成,每个节点包含数据域和指向下一个节点的指针域。链表的头节点是访问整个链表的入口。 单链表的节点类实现 在PHP中,可以通过类来定义链表节…