[摘要]本篇文章给大家带来的内容是关于laravel中validator的使用方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。web 开发过程中经常会需要进行参数验证,l...
本篇文章给大家带来的内容是关于laravel中validator的使用方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
web 开发过程中经常会需要进行参数验证,laravel 中我们常用 validator 或者 request 这两种方法来进行验证,但是这两种验证都不是很方便进行自定义提示信息,自定义验证规则,所以下面来介绍一种很方便的用法:
新建抽象类
<?php
namespace App\Http\Validators;
use Validator;
abstract class AbstractValidator
{
    /**
     * Validator
     *
     * @var \Illuminate\Validation\Factory
     */
    protected $validator;
    /**
     * Validation data key => value array
     *
     * @var array
     */
    protected $data = array();
    /**
     * Validation errors
     *
     * @var array
     */
    protected $errors = array();
    /**
     * Validation rules
     *
     * @var array
     */
    protected $rules = array();
    /**
     * Validation messages
     *
     * @var array
     */
    protected $messages = array();
    /**
     * Validation codes
     *
     * @var array
     */
    protected $codes = array();
    public function __construct(array $data)
    {
        $this->data = $data;
        $this->before();
        $this->validator = Validator::make($this->data, $this->rules, $this->messages);
        $this->after();
    }
    /**
     * Set data to validate
     *
     * @return validator
     */
    public function getValidator()
    {
        return $this->validator;
    }
    /**
     * Set data to validate
     *
     * @return $this
     */
    public function with(array $data)
    {
        $this->data = $data;
        $this->before();
        $this->validator = $this->validator->make($this->data, $this->rules, $this->messages);
        $this->after();
        return $this;
    }
    /**
     * Validation passes or fails
     *
     * @return boolean
     */
    public function passes()
    {
        if ($this->validator->fails()) {
            $this->errors = $this->validator->messages();
            return false;
        }
        return true;
    }
    /**
     * Return errors, if any
     *
     * @return array
     */
    public function errors()
    {
        return $this->errors;
    }
    /**
     * Return errors codes, if any
     *
     * @return array
     */
    public function getCodes()
    {
        return $this->codes;
    }
    /**
     * getRules
     *
     * @return array
     */
    public function getRules()
    {
        return $this->rules;
    }
    /**
     * getData
     *
     * @return array
     */
    public function getData()
    {
        return $this->data;
    }
    /**
     * getErrors
     *
     * @return array
     */
    public function getErrors()
    {
        return $this->errors;
    }
    /**
     * getMessages
     *
     * @return array
     */
    public function getMessages()
    {
        return $this->messages;
    }
    /**
     * setRule
     *
     * @param string $key
     * @param string $value
     *
     * @return $this
     */
    public function setRule($key, $value)
    {
        $this->rules[$key] = $value;
        return $this;
    }
    /**
     * emptyRules
     *
     * @return $this
     */
    public function emptyRules()
    {
        $this->rules = array();
        return $this;
    }
    /**
     * sometimes
     *
     * @param  string       $attribute
     * @param  string array $rules
     * @param  callable     $callback
     *
     * @return $this
     */
    public function sometimes($attribute, $rules, callable $callback)
    {
        $this->validator->sometimes($attribute, $rules, $callback);
        return $this;
    }
    /**
     * resolver
     *
     * @param  Closure $resolver
     *
     * @return $this
     */
    public function resolver(Closure $resolver)
    {
        Validator::resolver($resolver);
        return $this;
    }
    /**
     * replacer
     *
     * @param  Closure $resolver
     *
     * @return $this
     */
    public function replacer($replace, Closure $resolver)
    {
        Validator::replacer($replace, $resolver);
        return $this;
    }
    /**
     * extendImplicit
     *
     * @param  Closure $resolver
     *
     * @return $this
     */
    public function extendImplicit($extendImplicit, Closure $resolver)
    {
        Validator::extendImplicit($extendImplicit, $resolver);
        return $this;
    }
    /**
     * extend
     *
     * @param  string          $rule
     * @param  \Closure string $extension
     * @param  string          $message
     *
     * @return $this
     */
    public function extend($rule, $extension, $message = null)
    {
        Validator::extend($rule, $extension, $message);
        return $this;
    }
    /**
     * before (extend(),resolver())
     *
     * @return $this
     */
    public function before()
    {
    }
    /**
     * after(sometimes())
     *
     * @return $this
     */
    public function after()
    {
    }
}