购物车删除所有数量,而不是一个


Shopping cart deletes all quantities instead of one

我试图在PHP中创建一个简单的购物车。我已经设法将项目添加到会话中。如果您添加相同的项目,数量将更新。

然而,当我删除一个数量大于1的项目时,它将删除该项目的所有内容,而不是从数量中减去1。

我想知道是否有人可以检查我可能做错了什么?

取产品ID:

<a href="checkout.php?id=<?php echo $earthProducts -> id; ?>"> Order Now </a>
我有一个Item类:
<?php
Class Item{
var $id;
var $name;
var $price;
var $quantity;
}
?>

在结帐页面上,它将显示当前在购物车中的所有产品:

require 'item.php';
    if (isset($_GET['id'])) {
        $result = mysqli_query($con, 'SELECT * FROM earthProducts WHERE id=' . $_GET['id']);
        $earthProducts = mysqli_fetch_object($result);
        $item = new Item();
        $item->id = $earthProducts->id;
        $item->name = $earthProducts->name;
        $item->price = $earthProducts->price;
        $item->quantity = 1;
        // Check product is existing in cart
        $index = -1;
        $cart = unserialize(serialize($_SESSION['cart']));
        for ($i = 0; $i < count($cart); $i++)
            if ($cart[$i]->id == $_GET['id']) {
                $index = $i;
                break;
            }
        if ($index == -1) {
            $_SESSION['cart'] [] = $item;
        } else {
            $cart[$index]->quantity++;
            $_SESSION['cart'] = $cart;
        }
    }
    ?>

然后打印带有删除该商品按钮的购物车:

<table cellpadding="2" cellspacing="2" border="1">
                    <tr>
                        <th>Option</th>
                        <th>Id</th>
                        <th>Name</th>
                        <th>Price</th>
                        <th>Quantity</th>
                        <th>Sub Total</th>
                    </tr>
                    <?php
                    $cart = unserialize(serialize($_SESSION['cart']));
                    $s = 0;
                    $index = 0;
                    for ($i = 0; $i < count($cart); $i++) {
                        $s += $cart[$i]->price * $cart[$i]->quantity;
                        ?>
                        <tr>
                            <td> <a href="checkout.php?index=<?php echo $index; ?>" onclick="return confirm('Are you sure?')">Delete</td>
                            <td><?php echo $cart[$i]->id; ?></td>
                            <td><?php echo $cart[$i]->name; ?></td>
                            <td><?php echo $cart[$i]->price; ?></td>
                            <td><?php echo $cart[$i]->quantity; ?></td>
                            <td><?php echo $cart[$i]->price * $cart[$i]->quantity; ?></td>
                        </tr>
                        <?php
                        $index++;
                    }
                    ?>
                    <tr>
                        <td colspan="4" align="right">Sum</tr>
                    <td align="left"> <?php echo $s ?></td>
                </table>
                <br>
                <a href="earth_products.php"> Continue Shopping </a>
                <br>
                <br>
                <?php
                print_r($cart);
                ?>

我的代码删除购物车中的一个项目(这是错误的):

// Delete product in cart
    if (isset($_GET['index'])) {
        $cart = unserialize(serialize($_SESSION['cart']));
        unset($cart[$_GET['index']]);
        $cart = array_values($cart);
        $_SESSION['cart'] = $cart;
    }

因此,如果我有item-1,数量为1,我按delete键,这将删除它。如果item-2的数量为2,它将删除两个数量,并从购物车中删除item-2。

如果有人能帮助我,我先谢谢你。

您需要在取消设置之前检查数量,像这样的操作应该可以工作:

if (isset($_GET['index'])) {
    $cart = unserialize(serialize($_SESSION['cart']));
    if ($cart[$_GET['index']]->quantity == 1){
       unset($cart[$_GET['index']]);
    }else{
       $cart[$_GET['index']]->quantity--;
    }
    $cart = array_values($cart);
    $_SESSION['cart'] = $cart;
}

您需要减少商品的数量,而不是仅仅删除它,因为当数量大于1时,您的代码将从购物车中完全删除该商品。

另外,在SQL代码中直接使用$_GET变量是非常危险的,这使得进行SQL注入和转储数据库变得非常容易。