Backpack控制器中的验证没有明确的限制,但是您可以使用Laravel自带的验证器进行验证,并在Backpack中实现。下面是基本示例代码:
在您的控制器中,您可以使用以下代码来验证输入:
public function store(StoreRequest $request)
{
// 获取和验证输入
$validated = $request->validated();
// 将验证后的值存入数据库
$model = new YourModel([
'name' => $validated['name'],
'email' => $validated['email'],
'password' => Hash::make($validated['password']),
]);
$model->save();
return redirect()->back()->with('success', 'The resource has been created!');
}
在上面的代码中,StoreRequest
是一个Laravel自带的表单验证请求。您需要在app/Http/Requests
目录下创建它并定义规则:
class StoreRequest extends FormRequest
{
public function authorize()
{
return true;
}
public function rules()
{
return [
'name' => 'required|min:3|max:255',
'email' => 'required|email|max:255|unique:users,email',
'password' => 'required|min:6',
];
}
}
在上面的代码中,rules()
方法定义了输入验证规则。 您可以针对每个字段定义一组规则。 例如,“名称”字段是必需且必须具有3到255个字符。 “电子邮件”字段是必需且必须为有效的电子邮件格式。 “密码”字段也是必需的,而且必须至少有6个字符。
您还可以在您的请求类中定义其他验证程序,例如withValidator()
方法:
class StoreRequest extends FormRequest
{
public function authorize()
{
return true;
}
public function rules()
{
return [
'name' => 'required|min:3|max:255',
'email' => 'required|email|max:255|unique:users,email',
'password' => 'required|min:6',
];
}
public function withValidator($validator)
{
$validator->after(function ($validator) {
if ($this->somethingElseIsInvalid()) {
$validator->errors()->add('field', 'Something is wrong with this field!');
}
});
}
protected function somethingElseIsInvalid