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)