如何優(yōu)雅的使用 laravel 的 validator驗(yàn)證方法
web 開(kāi)發(fā)過(guò)程中經(jīng)常會(huì)需要進(jìn)行參數(shù)驗(yàn)證,laravel 中我們常用 validator 或者 request 這兩種方法來(lái)進(jìn)行驗(yàn)證,但是這兩種驗(yàn)證都不是很方便進(jìn)行自定義提示信息,自定義驗(yàn)證規(guī)則,所以下面來(lái)介紹一種很方便的用法:
新建抽象類
<?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個(gè)字符', 'name.test' => '測(cè)試', ); /** * 自定義驗(yàn)證規(guī)則或者擴(kuò)展Validator類 */ public function before() { $this->extend('test', function ($attribute, $value, $parameters) { return bool; }); } }
路由中如何使用
Route::post('/', ['middleware' => ['valiAdmin:Test'], 'uses' => 'IndexController@test']);
具體使用可以自行配置~
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue props對(duì)象validator自定義函數(shù)實(shí)例
- Spring Validator接口校驗(yàn)與全局異常處理器
- BootstrapValidator實(shí)現(xiàn)表單驗(yàn)證功能
- laravel 解決Validator使用中出現(xiàn)的問(wèn)題
- SpringBoot 使用hibernate validator校驗(yàn)
- Spring中校驗(yàn)器(Validator)的深入講解
- Spring MVC+FastJson+hibernate-validator整合的完整實(shí)例教程
- springboot使用Validator校驗(yàn)方式
- springboot使用hibernate validator校驗(yàn)方式
- springboot validator枚舉值校驗(yàn)功能實(shí)現(xiàn)
相關(guān)文章
Laravel接收前端ajax傳來(lái)的數(shù)據(jù)的實(shí)例代碼
本篇文章主要介紹了Laravel接收前端ajax傳來(lái)的數(shù)據(jù)的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-07-07PHP程序員簡(jiǎn)單的開(kāi)展服務(wù)治理架構(gòu)操作詳解(二)
這篇文章主要介紹了PHP程序員簡(jiǎn)單的開(kāi)展服務(wù)治理架構(gòu)操作,結(jié)合實(shí)例形式分析了rpc客戶端與服務(wù)器相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-05-05用 Composer構(gòu)建自己的 PHP 框架之使用 ORM
經(jīng)過(guò)前三篇文章 基礎(chǔ)準(zhǔn)備 、 構(gòu)建路由 和 設(shè)計(jì) MVC ,我們已經(jīng)得到了一個(gè)結(jié)構(gòu)比較完整的 MVC 架構(gòu)的 PHP 微框架,但是距離一個(gè)真正能夠上手使用的框架還差一樣?xùn)|西: 數(shù)據(jù)庫(kù)封裝 ,本篇就將講述如何集成一個(gè) ORM Composer 包2014-10-10PHP文件上傳小程序 適合初學(xué)者學(xué)習(xí)!
這篇文章主要為大家詳細(xì)介紹了PHP文件上傳小程序,給初學(xué)者提供的PHP文件上傳小程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05