
本文档介绍了在 Laravel 中验证嵌套 JSON 对象,并向自定义验证规则传递参数的实用方法。通过动态构建验证规则,你可以将当前数组索引下的对象传递给自定义验证器,从而实现更灵活和强大的数据验证逻辑。
在 Laravel 中,验证嵌套的 JSON 数据并向自定义验证器传递参数,通常需要动态地构建验证规则。以下是一个详细的步骤和示例,说明如何实现这一目标。
核心思路:动态构建验证规则
主要的策略是根据 seats 数组的长度,动态地生成验证规则。这样,我们就可以在创建 SeatIsAvailable 验证器实例时,将当前 seat 对象传递给它。
具体步骤:
-
修改 rules() 方法:
不再在 rules() 方法中直接定义 seats 相关的验证规则,而是调用一个名为 seatsRules() 的新方法来生成这些规则。
-
创建 seatsRules() 方法:
这个方法负责遍历 seats 数组,并为每个 seat 对象动态地创建验证规则。关键在于,在创建 SeatIsAvailable 验证器实例时,将当前 seat 对象作为参数传递给构造函数。
代码示例:
<?php
namespace App/Http/Requests/App;
use App/Rules/SeatIsAvailable;
use Illuminate/Foundation/Http/FormRequest;
class CheckoutRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array
*/
public function rules()
{
$rules = [
'company' => 'required',
'seats' => 'required|array',
];
return array_merge($rules, $this->seatsRules());
}
private function seatsRules(): array
{
$rules = [];
foreach ((array) $this->request->get('seats') as $key => $seat) {
$rules["seats.$key.seat_no"] = ['required', new SeatIsAvailable($seat)];
$rules["seats.$key.schedule_id"] = 'required|numeric';
$rules["seats.$key.date"] = 'required|date';
}
return $rules;
}
}
登录后复制
代码解释:
- rules() 方法:定义了 company 和 seats 的基本验证规则,然后将 seatsRules() 方法返回的规则合并到一起。
- seatsRules() 方法:
- 首先,获取 seats 数组。
- 然后,使用 foreach 循环遍历 seats 数组。 $key 代表数组的索引,$seat 代表当前索引对应的 seat 对象。
- 对于每个 seat 对象,动态地创建验证规则。 例如,seats.0.seat_no,seats.1.seat_no 等。
- 关键的一步是 new SeatIsAvailable($seat),这里将 $seat 对象传递给了 SeatIsAvailable 验证器的构造函数。
- 最后,返回包含所有动态生成的验证规则的数组。
SeatIsAvailable 验证器示例:
<?php
namespace App/Rules;
use Illuminate/Contracts/Validation/Rule;
class SeatIsAvailable implements Rule
{
protected $seat;
public function __construct($seat)
{
$this->seat = $seat;
}
/**
* Determine if the validation rule passes.
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
// 使用 $this->seat 来访问传递进来的 seat 对象
$scheduleId = $this->seat['schedule_id'];
$date = $this->seat['date'];
// 在这里编写你的验证逻辑,例如检查座位是否可用
// 可以使用 $value (seat_no), $scheduleId, $date 来进行验证
// 示例:
// $isAvailable = checkSeatAvailability($value, $scheduleId, $date);
// return $isAvailable;
return true; // 替换为你的实际验证逻辑
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return 'The seat is not available.';
}
}
登录后复制
注意事项:
- 确保 SeatIsAvailable 验证器能够正确接收和使用传递进来的 $seat 对象。
- 在 passes() 方法中,使用 $this->seat 访问传递进来的数据,并编写实际的验证逻辑。
- $attribute 参数代表当前验证的字段名,例如 seats.0.seat_no。 $value 参数代表该字段的值,例如座位号。
- 根据实际需求调整验证规则和错误消息。
总结:
通过动态构建验证规则,可以在 Laravel 中灵活地验证嵌套的 JSON 数据,并将参数传递给自定义验证器。这种方法使得验证逻辑更加强大和可定制,可以满足各种复杂的数据验证需求。
以上就是使用 Laravel 验证嵌套 JSON 数据并传递参数到自定义验证器的详细内容,更多请关注php中文网其它相关文章!