- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我尝试创建新订单时出现此错误:
"error": "array_merge(): 预期参数 1 为数组,给定为 null"
这里是我尝试用它创建新订单的整个函数,我尝试了 20 次,它工作正常,但一段时间后它停止工作并出现上述错误
public function placeOrder()
{
$user_id = auth()->id();
try {
$cart = Cart::where('client_id', '=', $user_id)->first();
$cartDetails = CartDetail::where('cart_id', '=', $cart->id)->get();
}catch (Exception $e){
return response()->json(["error" =>$e->getMessage()]);
}
try {
foreach ($cartDetails as $cartDetail){
$item = StoreItem::where('item_id', '=', $cartDetail->item_id)->first();
$this->items_total += $cartDetail->quantity;
$discountedPrice = ($item->unit_price * $item->discount) / 100;
$this->total_amount += $cartDetail->quantity * $discountedPrice;
}
}catch (Exception $e){
return response()->json(["error" =>$e->getMessage()]);
}
if(count($cartDetails->toArray()) == 0){
return response()->json(["warning" => "Please Add Cart Items"]);
}
$storeId = $cartDetails[0]->store_id;
try {
$store = Store::findOrFail($storeId);
$address = Address::where('user_id', '=', $user_id)->where('is_default', '=', true)->first();
}catch (Exception $e){
return response()->json(["error" => $e->getMessage()]);
}
$delivery_charge = 2;
$final_total = $this->total_amount + $delivery_charge;
$address_id = $address->id;
try {
$data = [
'items_total' => $this->items_total,
'total_amount' => $this->total_amount,
'is_paid' => false,
'delivery_charge' => $delivery_charge,
'shopper_earning' => $delivery_charge / 1.5,
'final_total' => $final_total,
'client_id' => $user_id,
'store_id' => $store->id,
'address_id' => $address_id,
'currency_id' => $store->currency_id
];
$createdOrder = Order::create($data);
if ($createdOrder){
foreach ($cartDetails as $cartDetail){
$cartDetail->delete();
}
event(new CartUpdated($cart->id, $user_id));
}
return response()->json(['success' => $createdOrder]);
}catch (Exception $e){
return response()->json(["error" =>$e->getMessage()]);
}
}
当我尝试调试它时,错误在 Order::create($data);
为什么会出现这个错误?
编辑:
调试控制台:
{
"message": "array_merge(): Expected parameter 1 to be an array, null given",
"exception": "ErrorException",
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastEvent.php",
"line": 78,
"trace": [
{
"function": "handleError",
"class": "Illuminate\\Foundation\\Bootstrap\\HandleExceptions",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastEvent.php",
"line": 78,
"function": "array_merge"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastEvent.php",
"line": 64,
"function": "getPayloadFromEvent",
"class": "Illuminate\\Broadcasting\\BroadcastEvent",
"type": "->"
},
{
"function": "handle",
"class": "Illuminate\\Broadcasting\\BroadcastEvent",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php",
"line": 33,
"function": "call_user_func_array"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Container/Util.php",
"line": 36,
"function": "Illuminate\\Container\\{closure}",
"class": "Illuminate\\Container\\BoundMethod",
"type": "::"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php",
"line": 91,
"function": "unwrapIfClosure",
"class": "Illuminate\\Container\\Util",
"type": "::"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php",
"line": 35,
"function": "callBoundMethod",
"class": "Illuminate\\Container\\BoundMethod",
"type": "::"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Container/Container.php",
"line": 592,
"function": "call",
"class": "Illuminate\\Container\\BoundMethod",
"type": "::"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Bus/Dispatcher.php",
"line": 94,
"function": "call",
"class": "Illuminate\\Container\\Container",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Pipeline/Pipeline.php",
"line": 128,
"function": "Illuminate\\Bus\\{closure}",
"class": "Illuminate\\Bus\\Dispatcher",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Pipeline/Pipeline.php",
"line": 103,
"function": "Illuminate\\Pipeline\\{closure}",
"class": "Illuminate\\Pipeline\\Pipeline",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Bus/Dispatcher.php",
"line": 98,
"function": "then",
"class": "Illuminate\\Pipeline\\Pipeline",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastManager.php",
"line": 114,
"function": "dispatchNow",
"class": "Illuminate\\Bus\\Dispatcher",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php",
"line": 289,
"function": "queue",
"class": "Illuminate\\Broadcasting\\BroadcastManager",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php",
"line": 212,
"function": "broadcastEvent",
"class": "Illuminate\\Events\\Dispatcher",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Broadcasting/PendingBroadcast.php",
"line": 57,
"function": "dispatch",
"class": "Illuminate\\Events\\Dispatcher",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Foundation/helpers.php",
"line": 218,
"function": "__destruct",
"class": "Illuminate\\Broadcasting\\PendingBroadcast",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/app/Observers/OrderStatusObserver.php",
"line": 15,
"function": "broadcast"
},
{
"function": "created",
"class": "App\\Observers\\OrderStatusObserver",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php",
"line": 388,
"function": "call_user_func_array"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php",
"line": 218,
"function": "Illuminate\\Events\\{closure}",
"class": "Illuminate\\Events\\Dispatcher",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasEvents.php",
"line": 188,
"function": "dispatch",
"class": "Illuminate\\Events\\Dispatcher",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Model.php",
"line": 886,
"function": "fireModelEvent",
"class": "Illuminate\\Database\\Eloquent\\Model",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Model.php",
"line": 728,
"function": "performInsert",
"class": "Illuminate\\Database\\Eloquent\\Model",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php",
"line": 767,
"function": "save",
"class": "Illuminate\\Database\\Eloquent\\Model",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Support/helpers.php",
"line": 433,
"function": "Illuminate\\Database\\Eloquent\\{closure}",
"class": "Illuminate\\Database\\Eloquent\\Builder",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php",
"line": 768,
"function": "tap"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Support/Traits/ForwardsCalls.php",
"line": 23,
"function": "create",
"class": "Illuminate\\Database\\Eloquent\\Builder",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Model.php",
"line": 1728,
"function": "forwardCallTo",
"class": "Illuminate\\Database\\Eloquent\\Model",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Model.php",
"line": 1740,
"function": "__call",
"class": "Illuminate\\Database\\Eloquent\\Model",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/app/Http/Controllers/Api/OrderController.php",
"line": 108,
"function": "__callStatic",
"class": "Illuminate\\Database\\Eloquent\\Model",
"type": "::"
},
{
"function": "placeOrder",
"class": "App\\Http\\Controllers\\Api\\OrderController",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Routing/Controller.php",
"line": 54,
"function": "call_user_func_array"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php",
"line": 45,
"function": "callAction",
"class": "Illuminate\\Routing\\Controller",
"type": "->"
},
{
"file": "/home/sohaib/Desktop/Final-Project/Discounts/vendor/laravel/framework/src/Illuminate/Routing/Route.php",
"line": 239,
"function": "dispatch",
"class": "Illuminate\\Routing\\ControllerDispatcher",
"type": "->"
},
这大约是一半,但我认为已经足够了,所以我在一个名为 OrderStatusObserver 的类之前创建了一个类,老实说,我不知道它是如何工作的,但这个类包含以下代码:
<?php
namespace App\Observers;
use App\Events\OrderStatus;
use App\Order;
class OrderStatusObserver
{
public function created(Order $order)
{
broadcast(new OrderStatus($order));
}
}
这是我在 OrderStatus 事件中的 broadcastWith 函数:
public function broadcastWith()
{
if($this->order->status == 'accepted'){
return ['current_position' => 2, 'id' => $this->order->id];
}elseif ($this->order->status == 'inprogress'){
return ['current_position' => 3];
}elseif ($this->order->status == 'onway'){
return ['current_position' => 4];
}elseif ($this->order->status == 'delivered'){
return ['current_position' => 5];
}
}
当我评论 broadcast(new OrderStatus($order));
这一行时它工作正常,所以任何人都知道这是什么问题,希望任何人都可以帮助我的英语
最佳答案
我认为您在创建方法中使用了数组 _merge()。你能给我们看看这个吗?您还可以在将 $data 发送到您的方法之前检查它是否不为空。
只是为了解释为什么我要求您共享您的 OrderStatus
类:根据您的错误跟踪,问题来自 BroadcastEvent.php
中的函数 getPayloadFromEvent
:
protected function getPayloadFromEvent($event)
{
if (method_exists($event, 'broadcastWith')) {
return array_merge(
$event->broadcastWith(), ['socket' => data_get($event, 'socket')]
);
}
$payload = [];
foreach ((new ReflectionClass($event))->getProperties(ReflectionProperty::IS_PUBLIC) as $property) {
$payload[$property->getName()] = $this->formatProperty($property->getValue($event));
}
unset($payload['broadcastQueue']);
return $payload;
}
恰好在 array_merge 调用中:
return array_merge($event->broadcastWith(), ['socket' => data_get($event, 'socket')]);
所以当您的错误消息显示 "array_merge(): Expected parameter 1 to be an array, null given"
时,您的 broadcastWith 返回 null 而不是数组。
关于php - "error": "array_merge(): Expected parameter 1 to be an array, null given",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62226015/
最近开始学习oracle和sql。 在学习的过程中,我遇到了几个问题,我的 friend 在接受采访时被问到这些问题。 SELECT * FROM Employees WHERE NULL IS N
这个问题在这里已经有了答案: Can we subtract NULL pointers? (4 个回答) 关闭 2 个月前。 是否定义了NULL - NULL? (char *)NULL - (ch
是否有推荐的方法(根据 .net Framework 指南)检查 null,例如: if (value == null) {//code1} else {//code2} 或 if (value !=
我正在尝试将值插入数据库,但出现这样的错误任何人都可以告诉我为什么该值为空,如下所示: An exception occurred while executing 'INSERT INTO perso
这个问题在这里已经有了答案: String concatenation with a null seems to nullify the entire string - is that desire
您好,我正在 Android 联系人搜索模块中工作。我正在查询下方运行。 cur = context.getContentResolver().query(ContactsContract.Data.
下面的 SQL 表定义说明了从我的 MYSQL 数据库创建表的语句之一,该数据库是由我公司的前开发人员开发的。 DROP TABLE IF EXISTS `classifieds`.`category
我主要有应用程序开发背景。在编程语言中 variable == null或 variable != null有效。 当涉及到 SQL 时,以下查询不会给出任何语法错误,但也不会返回正确的结果。 sel
我在尝试检查某些元素是否为 NULL 时遇到段错误或不。任何人都可以帮忙吗? void addEdge(int i, int j) { if (i >= 0 && j > 0)
在 SQL 服务器中考虑到以下事实:Col1 和 Col2 包含数值和 NULL 值 SELECT COALESCE(Col1,Col2) 返回一个错误:“COALESCE 的至少一个参数必须是一个不
在 SQL 服务器中考虑到以下事实:Col1 和 Col2 包含数值和 NULL 值 SELECT COALESCE(Col1,Col2) 返回一个错误:“COALESCE 的至少一个参数必须是一个不
下面查询的关系代数表达式是什么?我找不到“Is Null”的表达式。 SELECT reader.name FROM reader LEFT JOIN book_borrow ON reader.ca
我正在尝试使用三元运算符来检查值是否为 null 并返回一个表达式或另一个。将此合并到 LINQ 表达式时,我遇到的是 LINQ 表达式的 Transact-SQL 转换试图执行“column = n
我在给定的代码中看到了以下行: select(0, (fd_set *) NULL, (fd_set *) NULL, (fd_set *) NULL, &timeout); http://linux
var re = /null/g; re.test('null null'); //> true re.test('null null'); //> true re.test('null null')
这个问题在这里已经有了答案: 关闭 13 年前。 我今天避开了一场关于数据库中空值的激烈辩论。 我的观点是 null 是未指定值的极好指示符。团队中有意见的其他每个人都认为零和空字符串是可行的方法。
由于此错误,我无法在模拟器中运行我的应用: Error:null value in entry: streamOutputFolder=null 或 gradle - Error:null value
我正在尝试在 Android 应用程序中创建电影数据库,但它返回错误。知道这意味着什么吗? public Cursor returnData() { return db.query(TABLE
我一直在检查浏览器中的日期函数以及运行时间 new Date (null, null, null); 在开发工具控制台中,它给出了有效的日期 Chrome v 61 回归 Sun Dec 31 189
为什么 NA==NULL 会导致 logical (0) 而不是 FALSE? 为什么 NULL==NULL 会导致 logical(0) 而不是 TRUE? 最佳答案 NULL 是一个“零长度”对象
我是一名优秀的程序员,十分优秀!