首页 > 开发 > PHP > 正文

Laravel4中的Validator验证扩展用法详解

2024-05-04 22:29:02
字体:
来源:转载
供稿:网友

本文实例讲述了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的格式。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);});            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表