当前位置:首页 > PHP

php实现收藏

2026-02-14 09:23:48PHP

实现收藏功能的方法

在PHP中实现收藏功能通常涉及数据库操作、用户认证和前端交互。以下是实现收藏功能的详细步骤:

数据库设计

创建两个表:users(用户表)和favorites(收藏表)。用户表存储用户信息,收藏表存储用户收藏的内容。

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    password VARCHAR(255) NOT NULL
);

CREATE TABLE favorites (
    id INT AUTO_INCREMENT PRIMARY KEY,
    user_id INT NOT NULL,
    item_id INT NOT NULL,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY (user_id) REFERENCES users(id)
);

用户认证

确保用户已登录才能执行收藏操作。可以使用PHP的Session机制实现用户认证。

session_start();
if (!isset($_SESSION['user_id'])) {
    header("Location: login.php");
    exit();
}

收藏操作

在页面中添加收藏按钮,并通过AJAX或表单提交实现收藏功能。

php实现收藏

<button id="favorite-btn" data-item-id="123">收藏</button>
<script>
document.getElementById('favorite-btn').addEventListener('click', function() {
    const itemId = this.getAttribute('data-item-id');
    fetch('favorite.php', {
        method: 'POST',
        headers: {
            'Content-Type': 'application/x-www-form-urlencoded',
        },
        body: 'item_id=' + itemId
    })
    .then(response => response.json())
    .then(data => {
        if (data.success) {
            alert('收藏成功');
        } else {
            alert('收藏失败');
        }
    });
});
</script>

后端处理

创建favorite.php文件处理收藏请求。

session_start();
if (!isset($_SESSION['user_id'])) {
    echo json_encode(['success' => false, 'message' => '未登录']);
    exit();
}

$itemId = $_POST['item_id'] ?? 0;
$userId = $_SESSION['user_id'];

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

// 检查是否已收藏
$stmt = $db->prepare("SELECT * FROM favorites WHERE user_id = ? AND item_id = ?");
$stmt->execute([$userId, $itemId]);
if ($stmt->fetch()) {
    echo json_encode(['success' => false, 'message' => '已收藏']);
    exit();
}

// 添加收藏
$stmt = $db->prepare("INSERT INTO favorites (user_id, item_id) VALUES (?, ?)");
if ($stmt->execute([$userId, $itemId])) {
    echo json_encode(['success' => true]);
} else {
    echo json_encode(['success' => false, 'message' => '收藏失败']);
}

取消收藏

实现取消收藏功能,与收藏类似,但执行删除操作。

php实现收藏

$stmt = $db->prepare("DELETE FROM favorites WHERE user_id = ? AND item_id = ?");
if ($stmt->execute([$userId, $itemId])) {
    echo json_encode(['success' => true]);
} else {
    echo json_encode(['success' => false, 'message' => '取消收藏失败']);
}

显示收藏列表

查询用户的收藏列表并显示。

$stmt = $db->prepare("SELECT item_id FROM favorites WHERE user_id = ?");
$stmt->execute([$userId]);
$favorites = $stmt->fetchAll(PDO::FETCH_COLUMN);

foreach ($favorites as $itemId) {
    echo "收藏项ID: " . htmlspecialchars($itemId) . "<br>";
}

安全性考虑

确保所有用户输入都经过验证和过滤,防止SQL注入和其他安全漏洞。

$itemId = filter_input(INPUT_POST, 'item_id', FILTER_VALIDATE_INT);
if ($itemId === false || $itemId === null) {
    echo json_encode(['success' => false, 'message' => '无效的收藏项']);
    exit();
}

性能优化

为频繁查询的字段添加索引,提高查询效率。

CREATE INDEX idx_user_item ON favorites (user_id, item_id);

通过以上步骤,可以实现一个完整的收藏功能,包括添加、取消和显示收藏列表。

标签: 收藏php
分享给朋友:

相关文章

php实现分页

php实现分页

PHP实现分页的基本方法 使用原生PHP实现分页功能需要结合数据库查询和HTML展示。以下是核心实现步骤: 数据库查询与分页逻辑 // 连接数据库 $conn = new mysqli('loca…

php 实现自动收货

php 实现自动收货

PHP 实现自动收货功能 自动收货功能通常用于电商系统,在订单超过一定时间未手动确认收货时自动完成订单。以下是实现方法: 数据库设计 需要订单表包含以下关键字段: CREATE TABLE…

php实现表单

php实现表单

PHP 表单基础实现 创建一个简单的 PHP 表单需要 HTML 表单结构和 PHP 处理脚本。以下是一个完整的示例: HTML 表单部分 (form.html) <form action=…

php 路由实现

php 路由实现

PHP 路由实现方法 在 PHP 中实现路由功能有多种方式,以下是几种常见的实现方法: 使用原生 PHP 实现 通过解析 URL 并匹配对应的控制器和动作: $request = $_SERVER…

php实现mysql

php实现mysql

PHP 连接 MySQL 的基本方法 PHP 提供了多种方式与 MySQL 数据库进行交互,以下是最常用的几种方法。 使用 MySQLi 扩展 MySQLi 是 MySQL 的改进扩展,支持面向对…

php实现接口

php实现接口

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