zoukankan      html  css  js  c++  java
  • Laravel4中的Validator

    不管写接口还是写web页面,实质都是传入参数,然后进行业务逻辑,然后再输出具体内容。所以,对参数的验证是不可避免的一个环节,比如传过来的email是不是为空,是不是合法的email格式?laravel已经为phper想到简化这种逻辑的办法了。就是Validator。

    Validator的使用

    制造一个验证器

    validator使用Validator::make可以制造一个验证器。然后使用验证器判断传入的参数是否是合法的。

    看make的定义:

    public Validator make(array $data, array $rules, array $messages = array(), array $customAttributes = array())
    
    

    $data是keyvalue的要验证的数据

    $rules是验证的规则

    $messages是提示信息

    $customAttributes是设置属性别名的

    其中后两个消息都是为了提示信息而设置的

    直接看一个例子,理解了就validator就理解了:

        public function getIndex()
        {
            $rules = array(
                'email' => 'required|email',
                'name' => 'required|between:1,20',
                'password' => 'required|min:8',
            );
            $message = array(
                "required"             => ":attribute 不能为空",
                "between"      => ":attribute 长度必须在 :min 和 :max 之间"
            );
    
            $attributes = array(
                "email" => '电子邮件',
                'name' => '用户名',
                'password' => '用户密码',
            );
    
            $validator = Validator::make(
                Input::all(), 
                $rules,
                $message,
                $attributes
            );
            if ($validator->fails()) {
                $warnings = $validator->messages();
                $show_warning = $warnings->first();
                return Response::Json(compact('show_warning'));
            }
            return Response::Json("ok");
        }
    

    在这个例子中

    如果你传递的参数为

    /index?name=12321321321321321321321

    会返回:

    {
        show_warning: "电子邮件 不能为空"
    }
    

    Input::all() 将所有参数传入进行验证
    (rule 规定了email字段不能为空,它必须符合email的格式。 )message 说明如果违反required规则的话,显示错误的格式为:“:attribute 不能为空”
    $attributes 说明了显示的错误中email显示为文字“电子邮件”

    上面几个设置加起来就导致了最后参数没传email的时候显示的错误信息为:
    “电子邮件 不能为空”

    Validator的验证扩展

    验证规则扩展

    你一定会遇到比如要验证是否手机号合法的问题,laravel的Validator没有提供手机号验证的规则,因为每个国家的手机号规则是不统一的。

    但是这个使用想使用Validator做验证怎么办呢?

    Validator::extend('mobile', function($attribute, $value, $parameters)
    {
        return preg_match('/^0?(13[0-9]|15[012356789]|18[0-9]|14[57])[0-9]{8}$/', $value);
    });
    

    然后在rule中就可以使用mobile做为规则了。

    这种扩展验证规则放到哪里呢?

    我建议是在filters同级目录下增加一个validator.php,然后再start/global.php中

    require app_path().'/validator.php';
    

    输出信息统一提示

    上面的那个例子中,(message和)attribute都需要在使用validator的时候自己定义,比较麻烦,有没有更好的方法能统一设置呢?

    validator的提示设置是按照语言来进行设置的。

    语言设置是config目录下的app.php里面的locale界定的。默认为en。

    而en对应的错误提示都在lang目录下的en目录里面的validation.php中设置。

    你可以看一眼lang/en/validation.php 就明白对应的英文提示信息怎么出来的了。

    要设置中文提示:

    • 修改config/app.php里面的locale,设置为ch
    • 创建 lang/ch/validation.php
    • 修改validation.php文件,将里面的提示信息修改为中文,注意提示信息中的:attribute在显示的时候会被替换成对应属性名称,attributes是设置属性的中文名字的。

    从这里也就看出来了laravel对跨语言的支持是什么样子的。

    lang下面的文件夹除了validation.php之外还有分页:pagination.php,提示:reminders.php文件。

    laravel自带了哪些rule规则呢?

    查看手册吧。。。laravel自带的验证规则

  • 相关阅读:
    .net 自带的两个内置委托
    Socket
    SQL EXISTS与IN的区别(2)
    一个选择题,写了一个类
    SQL Server- 存储过程(2)
    VS插件-JSEnhancements
    SQL Server- 存储过程(1)
    MVC-工作原理
    C#-属性
    SQL Server 中游标的使用
  • 原文地址:https://www.cnblogs.com/yjf512/p/4324159.html
Copyright © 2011-2022 走看看