4

如何使用数据库和 PHP 会话来存储用户的购物车?如果有帮助,我正在使用 CodeIgniter。

示例代码也很好。

4

3 回答 3

3

我建议您查看CodeIgnitor Session Class

此外,您可以查看Chris Shiflett对此主题的讨论。

于 2008-11-25T03:30:14.653 回答
1

我会像这样编写一个添加到购物篮的函数:

function AddToBasket(){
    if(is_numeric($_GET["ID"])){
        $ProductID=(int)$_GET["ID"];
        $_SESSION["Basket"][]=$ProductID;
        $sOut.=ShowBasketDetail();
        return $sOut; 
    }
}

在这个购物篮函数中,我们将产品 ID 保存在会话数组中。

这是我在展示篮功能中的内容:

function ShowBasket(){
    foreach($_SESSION[Basket] as $ProductID){
        $sql="select * from products where ProductID=$ProductID";
        $result=mysql_query($sql);
        $row=mysql_fetch_row($result);
        echo "Product: ".$row[0];
        }
}

对于会话篮中的每个 ProudctID,我们进行 SQL 查询以输出产品信息。

现在最后但并非最不重要的是,一个明确的篮子功能:

function ClearBasket(){
    unset($_SESSION[Basket]);
}

session_start();在将任何产品 ID 添加到会话篮之前,请不要忘记。也不要忘记该mysql_connect();功能,在对数据库进行任何查询之前,您需要它。

于 2008-11-25T13:40:21.787 回答
1

这个怎么样 ; - 当客人在购物车中添加一件商品时

  function addCartItem($item_id, $qty)
  {
    $basket = $this->session->userdata('basket');
    if(!$basket)
    {
       $this->session->set_userdata('basket', array($item_id => $qty));
    }
    else
    {
       ## get array from $basket and *merge some new value from input
    }
  }
于 2008-12-22T05:44:14.447 回答