我有一个表单请求验证文件,它检查的是一个非空('required')
的输入字段,然后它是否存在于表'table1'
的数据库中的值。
我想在同一个输入字段中添加第二条存在的规则,如果第二条存在的验证规则不符合,则返回一条消息:
public function rules()
{
return [
'tour' => 'required|exists:table1,id|//another exists: table2, id//'
];
}
public function messages()
{
return [
'tour.required' => 'Message 1!',
'tour.exists:table1,id' => 'Message 2!',
'tour.//another exists: table2, id//' => 'Message 3!'
];
}
现在只有第二条规则有效。任何想法怎么做?:)
提前谢谢大家!
答案 0 :(得分:1)
在这种情况下,您可以编写自定义验证规则。例如,让我们创建一个名为CustomValidator的类(将他放在'App \ Services'或其他你想要的文件夹中。)
CustomValidator.php
namespace App\Services;
class CustomValidator {
public function myexistsValidate($attribute, $value, $parameters, $validator) {
for ($i = 0; $i < count($parameters); $i += 2) {
$count = \DB::table($parameters[$i])->where($parameters[$i + 1], $value)->count();
if (!$count) {
return false;
}
}
return true;
}
}
我们创建了一个名为myexists
的新规则。这条规则可以接受以逗号分隔的一对参数:“myexists:table1,searchfield1,table2,searchfield2 ...”
我写了一个非常简单的例子来实现这个规则,你可以添加一些方法或其他验证......
接下来,您必须在方法boot
中的AppServiceProvider中注册自己的验证规则(作为第一个参数放置的字符串将是新规则的名称):
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
use \Validator;
class AppServiceProvider extends ServiceProvider
{
public function boot()
{
Validator::extend('myexists', 'App\Services\CustomValidator@myexistsValidate');
}
/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
}
接下来在FormRequest中的地方代码如下:
public function rules()
{
$rules = [
'id' => 'myexists:tableName1,field1,tableName2,field2',
];
return $rules;
}
您可以为此规则添加验证邮件,例如在lang\en\validation.php
文件中'myexists' => 'Field :attribute must exists in all described tables.'