牛骨文教育服务平台(让学习变的简单)

自定义验证规则

注册自定义验证规则

Laravel 提供了各种有用的验证规则,但是,您可能希望可以设定自定义验证规则。注册生成自定义的验证规则的方法之一就是使用 `Validator::extend` 方法:

Validator::extend("foo", function($attribute, $value, $parameters)
{
    return $value == "foo";
});

自定义验证器闭包接收三个参数:要被验证的 $attribute(属性) 的名称,属性的值 $value,传递至验证规则的 $parameters 数组。

您同样可以传递一个类和方法到 extend 方法中,取代原本的闭包:

Validator::extend("foo", "FooValidator@validate");

注意,您同时需要为您的自定义规则制订一个错误信息。您可以使用行内自定义信息数组或是在认证语言文件里新增。
扩展 Validator 类

除了使用闭包回调来扩展 Validator 外,您一样可以直接扩展 Validator 类。您可以写一个扩展自 IlluminateValidationValidator 的验证器类。您也可以增加验证方法到以 validate 为开头的类中:

<?php

class CustomValidator extends IlluminateValidationValidator {

    public function validateFoo($attribute, $value, $parameters)
    {
        return $value == "foo";
    }

}

拓展自定义验证器解析器

接下来,您需要注册您自定义验证器扩展:

Validator::resolver(function($translator, $data, $rules, $messages)
{
    return new CustomValidator($translator, $data, $rules, $messages);
});

当创建自定义验证规则时,您可能有时需要为错误信息定义自定义的占位符。您可以如上所述创建一个自定义的验证器,然后增加 replaceXXX 函数进验证器中。

protected function replaceFoo($message, $attribute, $rule, $parameters)
{
    return str_replace(":foo", $parameters[0], $message);
}

如果您想要增加一个自定义信息 "replacer" 但不扩展 Validator 类,您可以使用 Validator::replacer 方法:

Validator::replacer("rule", function($message, $attribute, $rule, $parameters)
{
    //
});