SimpleCart(js) 保存到数据库以用于登录会话


SimpleCart(js) save to database for login sessions

*

已解决 *

我在我的一个项目中实现了SimpleCart(js)。

一个人可以registerlogin.logged后,您可以使用购物车purchase items

我有一个问题,因为如果您使用其他帐户login,simplecart(js) 会将购物车保存到本地存储。您会看到相同的购物车结果。

有没有人为此提供php sql解决方案,为每个individual session用户将购物车结果存储到sql中?

我用这个解决了这个问题,这是一种基本技术,但它非常适合我的需要,我仍然会调整 php 以检查数据库中是否存在购物车项目,无论是更新还是创建。

jQuery

$(".saveCart").click(function(){
        $(".itemRow").each(function(){
            var custId = "<?php echo $_SESSION['Username'] ?>";
            var itemName = $(this).find(".item-name").text();
            var itemPrice = $(this).find(".item-price").text();
            var itemQty = $(this).find(".item-quantity").text();
            var itemTotal = $(this).find(".item-total").text();
            $.ajax({
                // Enter below the full path to your "cart" php file
                url: "cart.php",
                type: "POST",
                data: {custId: custId, itemName: itemName, itemPrice: itemPrice, itemQty: itemQty, itemTotal: itemTotal},
                cache: false,
                success: function (html) {
                  // If form submission is successful
                  if ( html == 1 ) {
                  }
                  // Double check if maths question is correct
                  else {
                  }
                }
            });            
        });
    });

.PHP

<?php
$con = mysql_connect("localhost","root","pass");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }
mysql_select_db("test", $con);
$sql="INSERT INTO cart (Id, itemName, itemPrice, itemQty, itemTotal)
VALUES
('$_POST[custId]','$_POST[itemName]','$_POST[itemPrice]','$_POST[itemQty]','$_POST[itemTotal]')";
if (!mysql_query($sql,$con))
  {
  die('Error: ' . mysql_error());
  }
if ($sql) { echo "1"; }
else {echo "2"; }
mysql_close($con);
?>
mysql_query("UPDATE table SET sessid = ".session_id()." WHERE user = ".$user_id);

类似的东西?