首先使用Session存储购物车数据,通过session_start()启动会话并初始化$_SESSION['cart'],添加商品时以商品ID为键存入数量,支持更新与删除操作,并在页面展示时结合数据库查询商品详情。接着为实现数据持久化,创建carts表存储user_id、product_id等信息,用户登录后将购物车数据写入数据库,利用INSERT ... ON DUPLICATE KEY UPDATE避免重复,访问时从数据库读取并关联商品表展示完整信息,同时在登录后同步Session与数据库数据。最后在前后端分离场景下,前端通过AJAX发送JSON格式数据,PHP通过php://input接收并解析,验证product_id和count有效性后存入Session或数据库,返回标准JSON响应供前端提示操作结果。

如果您正在开发一个电商网站,并希望用户能够将商品添加到购物车中进行结算,那么实现一个基于 PHP 的购物车功能是必不可少的。以下是完成该功能的具体步骤:
本文运行环境:联想小新Pro 16,Windows 11
一、使用 Session 存储购物车数据
利用 PHP 的 Session 机制可以方便地在服务器端保存用户的购物车信息,适合中小型项目快速实现。
1、启动 Session,在脚本开头调用 session_start() 函数以启用会话支持。
立即学习“PHP免费学习笔记(深入)”;
2、初始化购物车数组,检查 $_SESSION 是否已存在 cart 键,若不存在则设置为空数组。
3、添加商品时,接收前端传来的商品 ID 和数量,使用商品 ID 作为键名存入 $_SESSION['cart'] 中。
4、更新或删除商品时,通过商品 ID 查找并修改对应数量,或使用 unset() 删除指定项。
5、在页面展示购物车内容时,遍历 $_SESSION['cart'] 并从数据库查询对应的商品详情进行显示。
二、结合数据库持久化存储购物车
为了保证用户跨设备或重新登录后仍能恢复购物车内容,需将数据存储至数据库中。
1、创建数据库表如 carts,包含字段 user_id、product_id、quantity 和 created_at 等。
2、当用户添加商品时,先判断该用户是否已登录,若已登录则将数据写入数据库。
3、执行 SQL 插入或更新操作,使用 INSERT ... ON DUPLICATE KEY UPDATE(MySQL)语句避免重复记录。
4、用户访问购物车页面时,从数据库中查询该用户的所有购物车条目并与商品表关联获取名称、价格等信息。
5、同步 Session 与数据库数据,在用户登录后将 Session 中的临时购物车合并到数据库,并清空本地 Session 购物车。
三、通过 JSON 格式传输购物车数据
在前后端分离架构中,可采用 JSON 格式传递购物车信息,提升接口通用性。
1、前端通过 AJAX 发送 POST 请求,携带商品信息(如 product_id、count)以 JSON 字符串形式提交。
2、PHP 后端使用 file_get_contents("php://input") 获取原始输入流并解析为数组。
3、验证数据合法性,确保 product_id 存在且 count 为正整数。
4、将处理后的数据存入 Session 或写入数据库,并返回标准格式的 JSON 响应,包含状态码和消息。
5、前端根据返回结果提示“添加成功”或显示错误原因。











