Laravel 5中的FormRequests是验证和授权的好方法。 但是如果我必须验证包含一对多关系数据的请求,如何处理。 例如,如果我有简单的发票应用程序。 一张发票有很多服务。 我的表单发布请求包含以下数据:
array (size=5)
'date' => string '2014-11-14' (length=10)
'num' => string '175' (length=3)
'client_id' => string '5' (length=1)
'vat' => string '1' (length=1)
'services' =>
array (size=2)
0 =>
array (size=3)
'description' => string 'Service 1' (length=36)
'value' => string '10' (length=2)
'items' => string '2' (length=1)
1 =>
array (size=3)
'description' => string 'Service 2' (length=11)
'value' => string '20' (length=2)
'items' => string '2' (length=1)
现在在InvoiceFormRequest类中我可以验证发票数据,但是如何继续服务:
<?php namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
use Response;
class InvoiceFormRequest extends FormRequest
{
public function rules()
{
return [
'date' => 'required',
'num' => 'required',
'client_id' => 'required',
'vat' => 'required'
];
}
public function authorize()
{
return true;
}
}
提前致谢!
更新: 正如我在Laravel 5.2中阅读here一样,可以写下这样的内容:
'services.*.description' => 'required',
'services.*.value' => 'required:numeric',
'services.*.items' => 'required:integer'
答案 0 :(得分:2)
现在在Laravel 5.2中我们有阵列验证:
'services.*.description' => 'required',
'services.*.value' => 'required:numeric',
'services.*.items' => 'required:integer'
答案 1 :(得分:1)
您可以对规则中的“services”参数使用“array”选项,但当然这不会验证每个元素中包含的任何数据。
http://laravel.com/docs/master/validation#rule-array
所以,我可能会建议使用像Marwelln这样的东西,使用自定义验证器,以及“数组”规则。
您的规则可能最终会像这样
public function rules()
{
return [
'date' => 'required',
'num' => 'required',
'client_id' => 'required',
'vat' => 'required',
'services' => 'array|services'
];
}
并且自定义验证器可能是这样的(你应该把它放在ServiceProvider中)
Validator::extend('services', function($attribute, $value, $parameters)
{
//foreach $value as $service
//validate $service['description'], $service['value'], $service['items']
//return true or false depending on the validation of each element
});
希望它能帮助你找到正确的方向!
答案 2 :(得分:0)
也许是一种更自动的方法来实现该方法:
Validator::extend('ingredients', function($attribute, $value, $parameters)
{
$model = app("App\Models\\".Str::singular(Str::studly($attribute)));
return Validator::make($value, $model::$rules)->validate();
});