当前位置:首页 > PHP

php收藏实现

2026-03-12 21:26:09PHP

实现 PHP 收藏功能

PHP 实现收藏功能通常涉及数据库操作和用户交互逻辑。以下是实现收藏功能的常见方法和步骤:

数据库设计 创建收藏表需要包含用户ID和内容ID字段,例如:

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

添加收藏功能

// 检查用户是否登录
session_start();
if (!isset($_SESSION['user_id'])) {
    die('请先登录');
}

// 获取参数
$content_id = $_POST['content_id'];
$user_id = $_SESSION['user_id'];

// 检查是否已收藏
$stmt = $pdo->prepare("SELECT id FROM favorites WHERE user_id = ? AND content_id = ?");
$stmt->execute([$user_id, $content_id]);

if ($stmt->rowCount() > 0) {
    echo '已收藏';
} else {
    // 添加收藏
    $insert = $pdo->prepare("INSERT INTO favorites (user_id, content_id) VALUES (?, ?)");
    $insert->execute([$user_id, $content_id]);
    echo '收藏成功';
}

取消收藏功能

php收藏实现

$delete = $pdo->prepare("DELETE FROM favorites WHERE user_id = ? AND content_id = ?");
$delete->execute([$user_id, $content_id]);
echo '已取消收藏';

获取用户收藏列表

$stmt = $pdo->prepare("SELECT c.* FROM contents c 
                      JOIN favorites f ON c.id = f.content_id 
                      WHERE f.user_id = ?");
$stmt->execute([$user_id]);
$favorites = $stmt->fetchAll(PDO::FETCH_ASSOC);

// 输出收藏列表
foreach ($favorites as $item) {
    echo $item['title']."<br>";
}

前端交互实现 HTML部分可以这样设计:

<button class="favorite-btn" data-content-id="123">收藏</button>

JavaScript部分:

php收藏实现

$('.favorite-btn').click(function() {
    const contentId = $(this).data('content-id');
    $.post('/favorite.php', {content_id: contentId}, function(response) {
        alert(response);
    });
});

安全性考虑

  • 使用预处理语句防止SQL注入
  • 验证用户登录状态
  • 对输入参数进行过滤和验证
  • 实现CSRF防护

性能优化

  • 为常用查询字段添加索引
  • 考虑缓存热门收藏内容
  • 分页显示收藏列表

扩展功能

  • 收藏分类管理
  • 批量操作功能
  • 收藏导出功能
  • 收藏提醒功能

以上实现可以根据具体项目需求进行调整和扩展,核心思路是通过数据库记录用户与内容的关联关系,并提供相应的增删查改接口。

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

相关文章

php实现打印功能

php实现打印功能

PHP实现打印功能的方法 在PHP中实现打印功能可以通过多种方式完成,包括直接输出到浏览器、生成PDF文件、调用打印机接口等。以下是几种常见的方法: 直接输出HTML内容 PHP可以通过echo或p…

php实现聊天

php实现聊天

实现 PHP 聊天功能的方法 使用 WebSocket 和 PHP 实现实时聊天 WebSocket 是一种全双工通信协议,适合实现实时聊天功能。PHP 可以通过 Ratchet 库实现 WebSo…

php实现分类

php实现分类

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

php 实现下载

php 实现下载

PHP 实现文件下载的方法 使用 PHP 实现文件下载可以通过设置 HTTP 头信息,强制浏览器将文件作为附件下载而非直接打开。 基本下载实现 $file_path = 'path/to/your/…

无限分类实现 php

无限分类实现 php

无限分类的实现方法 无限分类通常用于构建多层级结构的数据,如商品分类、部门架构等。以下是几种常见的实现方式: 邻接列表模式(Adjacency List) 邻接列表是最简单的实现方式,通过在每个记录…

php 伪静态实现

php 伪静态实现

PHP 伪静态实现方法 伪静态(URL Rewrite)是一种通过服务器配置将动态URL转换为静态URL的技术,提升URL的可读性和SEO效果。以下是几种常见的实现方式: 使用Apache的mod_…