• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    如何优雅的使用 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()
     {
     }
    }
    
    

    新建中间件

    ?php
    
    namespace App\Http\Middleware;
    
    use Closure;
    use \Illuminate\Http\Request;
    
    class ValidateAdminMiddleware
    {
     /**
      * This namespace is applied to the controller routes in your routes file.
      *
      * In addition, it is set as the URL generator's root namespace.
      *
      * @var string
      */
     protected $namespace = 'App\Http\Validators';
    
     /**
      * Handle an incoming request.
      *
      * @param \Illuminate\Http\Request $request
      * @param \Closure     $next
      *
      * @return mixed
      */
     public function handle(Request $request, Closure $next, $validator = null)
     {
      if ($request->isMethod('POST')) {
       $type = $request->segment(1);
       if ($validator) {
        $validator = $this->namespace . '\\' . studly_case($type) . '\\' . studly_case($validator) . 'Validator';
        $validator = new $validator($request->all());
    
        if (!$validator->passes()) {
         if ($request->isAjax()) {
          return $validator->errors()->first();
         } else {
          return redirect()->back()
          ->withErrors($validator->getValidator())
          ->withInput();
         }
        }
       }
      }
      return $next($request);
     }
    }
    

    新建 TestTestValidator

    ?php
    
    namespace App\Http\Validators\Admin;
    
    use App\Http\Validators\AbstractValidator;
    
    class TestValidator extends AbstractValidator
    {
     /**
      * Validation rules
      *
      * @var Array
      */
     protected $rules = array(
      'name' => ['required', 'test', 'min:1'],
     );
    
     /**
      * Validation messages
      *
      * @var Array
      */
     protected $messages = array(
      'name.required' => '必填',
      'name.min' => '最少1个字符',
      'name.test' => '测试',
     );
    
     /**
      * 自定义验证规则或者扩展Validator类
      */
     public function before()
     {
      $this->extend('test', function ($attribute, $value, $parameters) {
       return bool;
      });
     }
    }

    路由中如何使用

    Route::post('/', ['middleware' => ['valiAdmin:Test'], 'uses' => 'IndexController@test']);

    具体使用可以自行配置~

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • vue props对象validator自定义函数实例
    • Spring Validator接口校验与全局异常处理器
    • BootstrapValidator实现表单验证功能
    • laravel 解决Validator使用中出现的问题
    • SpringBoot 使用hibernate validator校验
    • Spring中校验器(Validator)的深入讲解
    • Spring MVC+FastJson+hibernate-validator整合的完整实例教程
    • springboot使用Validator校验方式
    • springboot使用hibernate validator校验方式
    • springboot validator枚举值校验功能实现
    上一篇:php使用curl模拟浏览器表单上传文件或者图片的方法
    下一篇:PHP 获取客户端 IP 地址的方法实例代码
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    如何优雅的使用 laravel 的 validator验证方法 如何,优雅,的,使用,laravel,