我需要重建结帐页面,其中包含最新的废弃产品。
如果您已登录opencart消费者网站并点击此网址 - http://www.example.com/index.php?route=checkout/cart,它肯定会列出购物车中的所有商品(尚未购买)。
如果没有登录消费者网站,如果有人直接点击此网址 - http://www.example.com/index.php?route=checkout/cart&email=someone@example.com - 它会列出someone@example.com
(也称为abandoned products/cart
)尚未购买的所有商品,提供someone@example.com
是opencart网站的注册用户。
我想将该网址中的电子邮件地址作为查询字符串传递到结帐/购物车页面,并使用该地址返回该客户电子邮件的废弃产品。
如何在结帐/购物车页面中显示该电子邮件,并向用户显示废弃的购物车产品?
我对opencart
非常陌生,我对核心功能知之甚少,所以我搜索了如何实现这一目标,但是我找到了付费的扩展程序(例如THIS),我的要求是让它在URL中构建,我在上面解释过。
提供:Opencart
安装是库存版本,没有安装其他插件/插件。
修改
我试过了。
if(isset($this->request->get['email']))
{
$email = $this->request->get['email'];
$cart_details = $this->db->query("SELECT cart FROM " . DB_PREFIX . "customer c where c.email = '" . $email . "'"); // just for tesing, i will fix this to prevent SQL injection.
$this->session->data['cart']= $cart_details->row['cart'];
}
当我与"$cart_details->row['cart']"
回应时,它获得了所需的值,但即使将该值设置为session
,结帐页面也不会重建已放弃产品的列表。
答案 0 :(得分:14)
我更改了checkout / controller / checkout / cart.php索引方法,并添加了一项检查以查看自定义网址是否包含“cmail”。然后我验证网址中提供的电子邮件地址。此时,我查询数据库以获取客户的“购物车”列(注意我已使用escape
来阻止SQL注入),然后将其解码并放入会话中。如果您使用网址“localhost / index.php?route = checkout / cart& cmail=some@domain.com”访问该网站,您将在页面中重建购物车。我使用了以下代码。
if(isset($this->request->get['cmail']))
{
$email = $this->request->get['cmail'];
if(filter_var($email, FILTER_VALIDATE_EMAIL))
{
$cart_details = $this->db->query("SELECT cart,customer_id FROM " . DB_PREFIX . "customer WHERE LOWER(email) = '" . $this->db->escape(utf8_strtolower($email)) . "'");
if($cart_details->num_rows > 0)
{
$cart_data = $cart_details->row['cart'];
if ($cart_data && is_string($cart_data)) {
$cart = unserialize($cart_data);
foreach ($cart as $key => $value) {
$this->session->data['cart'][$key] = $value;
}
}
}
}
}