1

我正在 prestashop 中开发一种类似于“快速购买”的新功能。我创建了一个带有表格的新页面,其中介绍了产品代码和数量,然后按下按钮将它们保存在购物车中。

问题是登录成功后,如果直接访问这个新页面,似乎购物车没有初始化,所以当我尝试存储新产品时,由于新的购物车在ps_cart中不存在,我无法保存它们适当地。否则,登录后,如果我使用 prestashop 典型方式(例如从产品页面)添加产品,则成功创建购物车,因此可以使用我的方式添加更多产品,因为正在传播购物车的 ID。

到目前为止我所做的是这样的:

class QuickbuyControllerCore extends FrontController{

    public $php_self = 'quickbuy.php';

    public function init() {
        parent::init();
    }


    public function initContent() {
        parent::initContent();
        $this->setTemplate(_PS_THEME_DIR_.'quickbuy.tpl');
    }

    public function process(){
        global $cart, $cookie;
        // do some stuff to get product codes

        if(!empty($products)){
            foreach ($products as $id_product => $qty){
                $exists = Db::getInstance()->getValue('SELECT id_product FROM `'._DB_PREFIX_.'cart_product` WHERE id_product = ' . $id_product . ' AND id_cart = '.(int)$cart->id);

                if($exists === false){
                    $query = 'INSERT INTO `'._DB_PREFIX_.'cart_product`(`id_cart`, `id_product`, `id_product_attribute`, `quantity`, `date_add`) VALUES ';
                    $query .= '('.(int)$cart->id.', '.(int)$id_product.', 0 , '.(int)$unidades.', NOW()),';

                    $res = Db::getInstance()->Execute(rtrim($query, ','));
                }
                else{
                    $upd = 'UPDATE `'._DB_PREFIX_.'cart_product` SET quantity = quantity + ' . (int)$unidades . ' WHERE id_product = '.(int) $id_product.' AND id_cart = '.(int)$cart->id;
                    Db::getInstance()->Execute($upd);
                }
            }
        }
    }


    // Other methods like SetMedia, DisplayContent,...
}

Prestashop 可能会调用一些方法来创建购物车,我想我将其排除在外,但我找不到我必须调用哪个方法来创建购物车。

我也试过调用 $cart->save() 和 $cookie->write(),这创建了一个新的购物车,但是当我刷新页面时,购物车的 ID 已经丢失。

关于为什么购物车 ID 不通过页面传播的任何想法?

编辑:我忘了说我的 prestashop 版本是 1.4.5.1

4

1 回答 1

1

我正在从您的问题中提取答案并将其发布在此处以供将来的读者使用:

if (!isset($cart->id) OR !$cart->id){
    $cart->add();
    if ($cart->id)
        $cookie->id_cart = (int)($cart->id);
}
于 2014-07-08T14:43:28.837 回答