0

0

laravel中validator的使用方法介绍(代码示例)

不言

不言

发布时间:2018-11-12 13:58:24

|

4360人浏览过

|

来源于segmentfault

转载

本篇文章给大家带来的内容是关于laravel中validator的使用方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

web 开发过程中经常会需要进行参数验证,laravel 中我们常用 validator 或者 request 这两种方法来进行验证,但是这两种验证都不是很方便进行自定义提示信息,自定义验证规则,所以下面来介绍一种很方便的用法:

新建抽象类

 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()
    {
    }
}

新建中间件

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

 ['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']);

具体使用可以自行配置~

简单好用的鼠标悬停动画按钮
简单好用的鼠标悬停动画按钮

鼠标放上去会有一个很好的动画,可以自己订制,使用的方法非常简单,只需要看代码中的例子就很容易明白

下载

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

42

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

4

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

3

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号