
本文将介绍如何在 Laravel 应用程序中实现购物车功能,并限制用户不能从不同的店铺(`sponsor_id`)添加商品到同一个购物车会话中。我们将提供两种实现方案,一种是循环遍历现有购物车商品进行校验,另一种是将商品按店铺 ID 分组存储到不同的购物车中。 通过本文,你将学会如何在 Laravel 中更灵活地管理购物车,并根据业务需求进行定制。
方案一:循环校验 sponsor_id
此方案的核心思想是在添加商品到购物车之前,先检查购物车中是否已存在商品,如果存在,则遍历购物车中的所有商品,验证它们的 sponsor_id 是否与当前要添加的商品的 sponsor_id 一致。如果不一致,则阻止添加操作。
以下是修改后的 addToCart 方法代码:
public function addToCart(Request $request, $id)
{
$cart = session("cart");
$produk = Produk::detail_produk($id);
if (isset($cart[$id])) {
$cart[$id]["qty"]++;
session()->put('cart', $cart);
} else {
$num = count($cart);
if($num > 0){
$this_sponsor_id = $produk->sponsor_id;
foreach($cart as $produk_id => $produk_data){
if($produk_data['sponsor_id'] != $this_sponsor_id){
return false; // 或者返回错误信息,例如:return redirect()->back()->with('error', '不能添加来自不同店铺的商品!');
}
}
}
$cart[$id] = [
"sponsor_id" => $produk->sponsor_id,
"nama_produk" => $produk->nama_produk,
"harga_produk" => $produk->harga_produk,
"berat" => $produk->berat,
"gambar" => $produk->gambar,
"qty" => $request->qty
];
}
session(["cart" => $cart]);
return redirect()->back()->with('success', 'Produk Berhasil dimasukkan ke keranjang !!');
}代码解释:
- 首先,获取购物车会话数据。
- 检查要添加的商品是否已存在于购物车中,如果存在,则增加数量并更新会话。
- 如果购物车为空,则直接添加商品。
- 如果购物车不为空,则获取当前商品的 sponsor_id。
- 遍历购物车中的所有商品,比较它们的 sponsor_id 与当前商品的 sponsor_id 是否一致。
- 如果存在任何一个商品的 sponsor_id 与当前商品不一致,则返回 false,阻止添加操作。 更友好的做法是返回一个错误信息,提示用户不能添加来自不同店铺的商品。
- 如果所有商品的 sponsor_id 都一致,则将当前商品添加到购物车。
- 更新购物车会话并返回成功消息。
注意事项:
- 在实际应用中,应该使用更友好的方式处理 sponsor_id 不一致的情况,例如,显示错误消息给用户,或者清空购物车并添加新店铺的商品。
- Produk::detail_produk($id) 应该返回包含 sponsor_id 属性的商品对象。
- 代码中的 $produk_data->sponsor_id 需要修改为 $produk_data['sponsor_id'],因为 $cart 数组中的数据是关联数组,而不是对象。
方案二:按 sponsor_id 分组存储购物车
此方案将购物车会话数据按照 sponsor_id 分组存储,每个 sponsor_id 对应一个独立的购物车。这样,用户可以同时添加来自多个店铺的商品,但每个店铺的商品都存储在单独的购物车中。
主要更新介绍: 完美整合Discuz!论坛,实现一站式登陆、退出、注册; 同步所有会员资料; 新增购物车功能,商品购买更加方便、快捷; 新增部分快捷菜单,网站访问更加方便; 限制首页商品、店铺标题显示长度; 修正会员后台管理不能更改密码的错误; 完善商品显示页面所有功能链接; 修正后台标签管理部分错误; 修正前台学校列表不按后台顺序显示的错误; 修正搜索功能中学校名称过长导致显示紊乱的现象; 修正
以下是修改后的 addToCart 方法代码:
public function addToCart(Request $request, $id)
{
$produk = Produk::detail_produk($id);
$sponsor_id = $produk->sponsor_id;
$cart = session("cart", []); // 初始化 cart 为空数组,防止 undefined array key 错误
if(!isset($cart[$sponsor_id])){
$cart[$sponsor_id] = [];
}
if(isset($cart[$sponsor_id][$id])){
$cart[$sponsor_id][$id]["qty"]++;
} else {
$cart[$sponsor_id][$id] = [
"sponsor_id" => $sponsor_id,
"nama_produk" => $produk->nama_produk,
"harga_produk" => $produk->harga_produk,
"berat" => $produk->berat,
"gambar" => $produk->gambar,
"qty" => $request->qty
];
}
session(["cart" => $cart]);
return redirect()->back()->with('success', 'Produk Berhasil dimasukkan ke keranjang !!');
}代码解释:
- 首先,获取要添加的商品的 sponsor_id。
- 获取购物车会话数据,如果不存在,则初始化为空数组。
- 检查是否存在以 sponsor_id 为键的子购物车,如果不存在,则创建一个新的子购物车。
- 检查要添加的商品是否已存在于当前 sponsor_id 的子购物车中,如果存在,则增加数量。
- 如果商品不存在,则将其添加到当前 sponsor_id 的子购物车中。
- 更新购物车会话并返回成功消息。
注意事项:
- 此方案需要修改购物车页面的显示逻辑,需要根据 sponsor_id 分别显示每个店铺的商品。
- 在结算时,需要分别计算每个店铺的商品总价,并进行相应的处理。
- session("cart", []) 确保了即使session中没有cart,也能正常初始化为空数组,避免错误。
总结:
这两种方案都可以实现限制用户从不同店铺添加商品到同一个购物车会话的目的。第一种方案简单易懂,适用于只需要限制用户从单个店铺购买商品的场景。第二种方案更加灵活,允许用户同时添加来自多个店铺的商品,但需要修改购物车页面的显示和结算逻辑。 选择哪种方案取决于具体的业务需求。









