繁体   English   中英

Laravel - 在字符串上调用成员 function save()

[英]Laravel - Call to a member function save() on string

我无法将一系列项目从 session 保存到 mysql 数据库,但出现错误:

"Symfony \ Component \ Debug \ Exception \ FatalThrowableError (E_ERROR) Call to a member function save() on string"

当我执行 dd(Dump and Die) 时,数组显示如下:

    "{"1":{"name":"Bajiya","quantity":4,"price":"34.00"},
    "2":{"name":"Gulha","quantity":2,"price":"3.00"},
    "3":{"name":"kavaabu","quantity":1,"price":"2.00"}}"

下面是controller商店function:

public function storeCart(Request $request){

    $cart = new Cart;
    $cart= session()->get('cart');
    $cart =  json_encode($cart);
    $cart->save();
}

我的数据库中有一个表,其中包含 id 和 cart 列。 我希望将上面的数组保存在购物车列中。

谢谢

每次覆盖之前的变量$cart

$cart = new Cart; //put into $cart instance of Cart class
$cart = session()->get('cart'); // overwrite other data to variable $cart
$cart = json_encode($cart); // json_encode converts object/array to json (so at this moment you overwrite string to variable `$cart`
$cart->save(); //you're trying to call function on json)))

请尝试了解您到底想做什么))

适用于下面的 function。

public function storeCart(Request $request){

    $cart = new Cart();
    $cart->cart = $request->session()->get('cart');
    $cart->save();
    $request->session()->forget('cart');
    return redirect()->route('/');
}

用一个简单的术语来解释我的解释,您需要指向数据库中将保留记录的列。 代码可能如下所示

$cart = new Cart;
$cart->name= session()->get('name');
$cart->quantity =  session()->get('quantity');
$cart->price =  session()->get('price');
$cart->save();

由于您要保存一组项目,因此您可能希望使用 foreach 并且代码将更改为如下所示:

foreach ($cart as $item){
  $item->name= session()->get('name');
  $item->quantity =  session()->get('quantity');
  $item->price =  session()->get('price');
  $item->save();
}

您可能还需要考虑使用关系。 希望这有意义并有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM