当前位置:首页 > PHP

php购物车实现代码

2026-01-28 20:15:56PHP

基本购物车实现

PHP购物车可以通过Session或数据库存储商品信息。以下是一个基于Session的简单实现:

<?php
session_start();

// 添加商品到购物车
if (isset($_POST['add_to_cart'])) {
    $product_id = $_POST['product_id'];
    $quantity = $_POST['quantity'];

    if (!isset($_SESSION['cart'])) {
        $_SESSION['cart'] = array();
    }

    if (isset($_SESSION['cart'][$product_id])) {
        $_SESSION['cart'][$product_id] += $quantity;
    } else {
        $_SESSION['cart'][$product_id] = $quantity;
    }
}

// 从购物车移除商品
if (isset($_GET['remove'])) {
    $product_id = $_GET['remove'];
    unset($_SESSION['cart'][$product_id]);
}

// 更新购物车数量
if (isset($_POST['update_cart'])) {
    foreach ($_POST['quantity'] as $product_id => $quantity) {
        if ($quantity <= 0) {
            unset($_SESSION['cart'][$product_id]);
        } else {
            $_SESSION['cart'][$product_id] = $quantity;
        }
    }
}
?>

购物车显示页面

<?php
session_start();
if (!isset($_SESSION['cart']) || empty($_SESSION['cart'])) {
    echo "购物车为空";
    exit;
}

// 假设$products是从数据库获取的商品信息
$products = [
    1 => ['name' => '商品A', 'price' => 100],
    2 => ['name' => '商品B', 'price' => 200]
];
?>

<form method="post" action="cart.php">
<table>
    <tr>
        <th>商品名称</th>
        <th>单价</th>
        <th>数量</th>
        <th>小计</th>
        <th>操作</th>
    </tr>
    <?php 
    $total = 0;
    foreach ($_SESSION['cart'] as $product_id => $quantity): 
        $product = $products[$product_id];
        $subtotal = $product['price'] * $quantity;
        $total += $subtotal;
    ?>
    <tr>
        <td><?php echo $product['name']; ?></td>
        <td><?php echo $product['price']; ?>元</td>
        <td><input type="number" name="quantity[<?php echo $product_id; ?>]" value="<?php echo $quantity; ?>"></td>
        <td><?php echo $subtotal; ?>元</td>
        <td><a href="cart.php?remove=<?php echo $product_id; ?>">删除</a></td>
    </tr>
    <?php endforeach; ?>
    <tr>
        <td colspan="3">总计</td>
        <td><?php echo $total; ?>元</td>
        <td></td>
    </tr>
</table>
<input type="submit" name="update_cart" value="更新购物车">
</form>

数据库存储方案

对于需要持久化存储的购物车,可以使用数据库方案:

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

// 添加商品到购物车
function addToCart($user_id, $product_id, $quantity) {
    global $db;

    $stmt = $db->prepare("INSERT INTO cart (user_id, product_id, quantity) 
                         VALUES (?, ?, ?) 
                         ON DUPLICATE KEY UPDATE quantity = quantity + ?");
    $stmt->execute([$user_id, $product_id, $quantity, $quantity]);
}

// 获取用户购物车
function getCart($user_id) {
    global $db;

    $stmt = $db->prepare("SELECT p.id, p.name, p.price, c.quantity 
                         FROM cart c 
                         JOIN products p ON c.product_id = p.id 
                         WHERE c.user_id = ?");
    $stmt->execute([$user_id]);
    return $stmt->fetchAll(PDO::FETCH_ASSOC);
}

安全注意事项

购物车实现需要考虑以下安全措施:

php购物车实现代码

  • 对用户输入进行验证和过滤
  • 防止SQL注入攻击
  • 对商品ID进行验证,确保是有效商品
  • 对数量进行限制,防止负数或过大数值
// 安全过滤示例
$product_id = filter_input(INPUT_POST, 'product_id', FILTER_VALIDATE_INT);
$quantity = filter_input(INPUT_POST, 'quantity', FILTER_VALIDATE_INT, [
    'options' => ['min_range' => 1, 'max_range' => 99]
]);

if (!$product_id || !$quantity) {
    die('无效输入');
}

以上代码提供了PHP购物车的基本实现方案,可以根据实际需求进行扩展和完善。

标签: 购物车代码
分享给朋友:

相关文章

js实现分页功能代码

js实现分页功能代码

分页功能实现方法 客户端分页(前端处理数据) 适用于数据量较小且已全部加载到前端的情况。 // 示例数据 const data = Array.from({length: 100}, (_, i)…

jquery代码

jquery代码

以下是关于jQuery代码的常见用法和示例,涵盖基础操作、事件处理、DOM操作等核心功能: 基础语法 jQuery通过$()函数选择元素,支持CSS选择器语法: // 选择所有<p>元…

vue怎么实现文本代码实现

vue怎么实现文本代码实现

Vue 实现文本代码展示的方法 在 Vue 中展示代码文本通常需要结合语法高亮和格式化的功能,以下是几种常见的实现方式: 使用 <pre> 和 <code> 标签 通过 HT…

vue实现添加内容代码

vue实现添加内容代码

以下是一个基于 Vue.js 实现添加内容的代码示例,包含核心逻辑和关键步骤: 基础实现 模板部分(Template) <template> <div> <…

如何建立运行react代码

如何建立运行react代码

安装 Node.js 和 npm React 项目需要 Node.js 环境来运行,同时 npm(Node Package Manager)用于管理依赖。从 Node.js 官网 下载并安装最新稳定版…

react如何实现代码分离

react如何实现代码分离

React 代码分离的实现方法 使用动态导入(Dynamic Import) 动态导入是 ECMAScript 的特性,React 通过 React.lazy 和 Suspense 实现组件级代码分离…