我正在 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