如何使用数据库和 PHP 会话来存储用户的购物车?如果有帮助,我正在使用 CodeIgniter。
示例代码也很好。
我建议您查看CodeIgnitor Session Class。
此外,您可以查看Chris Shiflett对此主题的讨论。
我会像这样编写一个添加到购物篮的函数:
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();
功能,在对数据库进行任何查询之前,您需要它。
这个怎么样 ; - 当客人在购物车中添加一件商品时
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
}
}