如何看待移动的话费宝,年化大脑开发率高达9020

Posts - 368,
Articles - 0,
Comments - 908
-正确的时间经历正确的事情
17:52 by 轩脉刃, ... 阅读,
不管写接口还是写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 不能为空&,
=& &:attribute 长度必须在 :min 和 :max 之间&
$attributes = array(
&email& =& '电子邮件',
'name' =& '用户名',
'password' =& '用户密码',
$validator = Validator::make(
Input::all(),
$attributes
if ($validator-&fails()) {
$warnings = $validator-&messages();
$show_warning = $warnings-&first();
return Response::Json(compact('show_warning'));
return Response::Json(&ok&);
在这个例子中
如果你传递的参数为
/index?name=
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[]|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规则呢?
查看手册吧。。。专栏:laravel5学习笔记 - 博客频道 - CSDN.NET
> & & > &laravel5学习笔记
本专栏主要记录自己在学习laravel5的过程中对遇到的问题的思考,同时对于官方文档一些读起来让人摸不着头脑的部分进行一些自己的理解,并给出了相应的一些例子。后期将会使用laravel5作为app服务端开发框架,到时候如果条件允许也会记录后端开发笔记。
共12篇博文
随着近几年各类移动终端的迅速普及,基于地理位置的服务(LBS)和相关应用也越来越多,而支撑这些应用的最基础技术之一,就是基于地理位置信息的处理。我所在的项目也正从事相关系统的开发,我们使用的是Lara...
简介在 Laravel5 中,本身已经提供了丰富的验证规则供我们使用,但是天下应用奇葩多,做为程序员你会发现永远都有新的验证规则诞生,光是组合已经拯救不了你的项目了。这个时候就需要我们扩展 Valid...
问题描述在使用laravel的 seed 功能的时候,经常有同学会看到以下这个异常
[Illuminate\Database\Eloquent\MassAssignmentException]
问题描述也许标题写的不够清楚,实际情况是,在我使用laravel的过程中,需要将自己的一个类,通过服务提供者注册到IOC容器中,但是在实际操作过程中,出现了以下错误:Unresolvable depe...
OAuth2.0使用的场景越来越多,如果正确使用?本文针对Laravel5进行了一些探索,将相关的操作使用流程发布出来,供大家参考。
视图组件视图组件就是在视图被渲染前,会调用的闭包或类方法。如果你想在每次渲染某些视图时绑定数据,视图组件可以把这样的程序逻辑组织在同一个地方。对上面的话,理解如下:
这个php代码运行的时间是在渲染视...
Laravel框架的基础是一个功能强大的控制反转容器(IoC container)。 为了真正理解该框架,需要好好掌握该容器。然而我们需要了解,控制反转容器只是一种用于方便实现“依赖注入”的工具。但要...
学习laravel5已经有一段的时间了,深深被composer管理php包的功能感动,想想自己也来动手写个包,发布到packagist上。包功能介绍此包实现功能:laravel5使用百度UEditor...
什么是Facades,官方文档如是说:
Facades 提供一个 静态接口 给在应用程序的 服务容器 中可以取用的类。Laravel 附带许多 facades,甚至你可能已经在不知情的状况下使用过它们...
在app服务端开发中,常常会遇到此种情况:
某一个大的任务中,可以分割为1,2,3,4个小任务,其中2的完成依赖1,4的完成依赖2。那么1、2、4可以理解为一个事务,必须依次执行,否则任...
laravel5的路由支持缓存。需要执行以下命令:php artisan route:cache执行完毕后,报出以下错误:Route cache cleared!
[LogicException]
Java有Maven, Node.js有npm, ROR有gem, 这些语言的程序员在开心地使用包管理工具加速开发效率时,PHPer们还在复制粘贴的黑暗中。PHP在Composer之前,包管理的历史不...
1879265514Laravel框架表单验证详解
投稿:junjie
字体:[ ] 类型:转载 时间:
这篇文章主要介绍了Laravel框架表单验证详解,本文给出了Laravel表单基本验证例子、高级使用方法、验证方法介绍等,要的朋友可以参考下
基础验证例子
$validator = Validator::make(
array('name' =& 'Dayle'),
array('name' =& 'required|min:5')
传递给 make 函数的第一个参数是待验证的数据,第二个参数是对该数据需要应用的验证规则。
多个验证规则可以通过 "|" 字符进行隔开,或者作为数组的一个单独的元素。
通过数组指定验证规则
$validator = Validator::make(
array('name' =& 'Dayle'),
array('name' =& array('required', 'min:5'))
一旦一个 Validator 实例被创建,可以使用 fails (或者 passes)函数执行这个验证。
if ($validator-&fails())
// The given data did not pass validation
如果验证失败,您可以从验证器中获取错误消息。
$messages = $validator-&messages();
您也可以使用 failed 函数得到不带错误消息的没有通过验证的规则的数组。
$failed = $validator-&failed();
Validator 类提供了一些验证规则用于验证文件,比如 size、mimes等。在验证文件的时候,您可以和其他验证一样传递给验证器。
附带错误消息
在一个 Validator 实例上调用 messages 函数之后,将会得到一个 MessageBag 实例,该实例拥有很多处理错误消息的方便的函数。
获取一个域的第一个错误消息
echo $messages-&first('email');
获取一个域的全部错误消息
foreach ($messages-&get('email') as $message)
获取全部域的全部错误消息
foreach ($messages-&all() as $message)
检查一个域是否存在消息
if ($messages-&has('email'))
以某种格式获取一条错误消息
echo $messages-&first('email', '&p&:message&/p&');
  注意: 默认情况下,消息将使用与 Bootstrap 兼容的语法进行格式化。
  以某种格式获取所有错误消息
  foreach ($messages-&all('&li&:message&/li&') as $message)
错误消息 & 视图
一旦您执行了验证,您需要一种简单的方法向视图反馈错误消息。这在 Lavavel 中能够方便的处理。以下面的路由作为例子:
Route::get('register', function()
return View::make('user.register');
Route::post('register', function()
$rules = array(...);
$validator = Validator::make(Input::all(), $rules);
if ($validator-&fails())
return Redirect::to('register')-&withErrors($validator);
注意当验证失败,我们使用 withErrors 函数把 Validator 实例传递给 Redirect。这个函数将刷新 Session 中保存的错误消息,使得在下次请求中能够可用。
然而,注意我们没有必要明确的在 GET 路由中绑定错误消息到路由。这是因为 Laravel 总会检查 Session 中的错误,并自动绑定它们到视图如果它们是可用的。所以,对于每个请求,一个 $errors 变量在所有视图中总是可用的,允许您方便的认为 $errors 总是被定义并可以安全使用的。$errors 变量将是一个 MessageBag 类的实例。
所以,在跳转之后,您可以在视图中使用自动绑定的 $errors 变量:
&?php echo $errors-&first('email'); ?&
  可用的验证规则
  下面是一个所有可用的验证规则的列表以及它们的功能:
 Active URL
 After (Date)
 Alpha Dash
 Alpha Numeric
 Before (Date)
 Confirmed
 Date Format
 Different
 Exists (Database)
 Image (File)
 IP Address
 MIME Types
 Regular Expression
 Required
 Required If
 Required With
 Required Without
 Unique (Database)
验证此规则的值必须是 yes、 on 或者是 1。这在验证是否同意"服务条款"的时候非常有用。
active_url
验证此规则的值必须是一个合法的 URL,根据 PHP 函数 checkdnsrr。
after:date
验证此规则的值必须在给定日期之后,日期将通过 PHP 函数 strtotime 传递。
  验证此规则的值必须全部由字母字符构成。
alpha_dash
  验证此规则的值必须全部由字母、数字、中划线或下划线字符构成。
  验证此规则的值必须全部由字母和数字构成。
before:date
  验证此规则的值必须在给定日期之前,日期将通过 PHP 函数 strtotime 传递。
between:min,max
  验证此规则的值必须在给定的 min 和 max 之间。字符串、数字以及文件都将使用大小规则进行比较。
  验证此规则的值必须和 foo_confirmation 的值相同。比如,需要验证此规则的域是 password,那么在输入中必须有一个与之相同的 password_confirmation 域。
  验证此规则的值必须是一个合法的日期,根据 PHP 函数 strtotime。
date_format:format
  验证此规则的值必须符合给定的 format 的格式,根据 PHP 函数 date_parse_from_format。
different:field
  验证此规则的值必须与指定的 field 域的值不同。
  验证此规则的值必须是一个合法的电子邮件地址。
exists:table,column
  验证此规则的值必须在指定的数据库的表中存在。
  Exists 规则的基础使用
代码如下:'state' =& 'exists:states'
'state' =& 'exists:states,abbreviation'
您也可以指定更多的条件,将以 "where" 的形式添加到查询。
'email' =& 'exists:staff,email,account_id,1'
  验证此规则的值必须是一个图片 (jpeg, png, bmp 或者 gif)。
  in:foo,bar,...
  验证此规则的值必须在给定的列表中存在。
  integer
  验证此规则的值必须是一个整数。
  验证此规则的值必须是一个合法的 IP 地址。
  验证此规则的值必须小于最大值 value。字符串、数字以及文件都将使用大小规则进行比较。
  mimes:foo,bar,...
  验证此规则的文件的 MIME 类型必须在给定的列表中。
  MIME 规则的基础使用
'photo' =& 'mimes:jpeg,bmp,png'
  验证此规则的值必须大于最小值 value。字符串、数字以及文件都将使用大小规则进行比较。
not_in:foo,bar,...
  验证此规则的值必须在给定的列表中不存在。
  验证此规则的值必须是一个数字。
regex:pattern
  验证此规则的值必须符合给定的正则表达式。
  注意: 当使用 regex 模式的时候,有必要使用数组指定规则,而不是管道分隔符,特别是正则表达式中包含一个管道字符的时候。
  验证此规则的值必须在输入数据中存在。
required_if:field,value
  当指定的域为某个值的时候,验证此规则的值必须存在。
required_with:foo,bar,...
  仅当指定的域存在的时候,验证此规则的值必须存在。
required_without:foo,bar,...
  仅当指定的域不存在的时候,验证此规则的值必须存在。
same:field
  验证此规则的值必须与给定域的值相同。
size:value
验证此规则的值的大小必须与给定的 value 相同。对于字符串,value 代表字符的个数;对于数字,value 代表它的整数值,对于文件,value 代表文件以KB为单位的大小。
unique:table,column,except,idColumn
验证此规则的值必须在给定的数据库的表中唯一。如果 column 没有被指定,将使用该域的名字。
Unique 规则的基础使用
'email' =& 'unique:users'
'email' =& 'unique:users,email_address'
强制忽略一个给定的 ID
'email' =& 'unique:users,email_address,10'
  验证此规则的值必须是一个合法的 URL。
  定制错误消息
  如果有需要,您可以使用定制的错误消息代替默认的消息。这里有好几种定制错误消息的方法。
  传递定制消息到验证器
$messages = array(
 'required' =& 'The :attribute field is required.',
 $validator = Validator::make($input, $rules, $messages);
注意: :attribute 占位符将被实际的进行验证的域的名字代替,您也可以在错误消息中使用其他占位符。
其他验证占位符
  $messages = array(
  'same' =& 'The :attribute and :other must match.',
  'size' =& 'The :attribute must be exactly :size.',
  'between' =& 'The :attribute must be between :min - :max.',
  'in' =& 'The :attribute must be one of the following types:
  有些时候,您可能希望只对一个指定的域指定定制的错误消息:
  对一个指定的域指定定制的错误消息
$messages = array(
'email.required' =& 'We need to know your e-mail address!',
在一些情况下,您可能希望在一个语言文件中指定错误消息而不是直接传递给 Validator。为了实现这个目的,请在 app/lang/xx/validation.php 文件中添加您的定制消息到 custom 数组。
在语言文件中指定错误消息
'custom' =& array(
'email' =& array(
'required' =& 'We need to know your e-mail address!',
定制验证规则
Laravel 提供了一系列的有用的验证规则;但是,您可能希望添加自己的验证规则。其中一种方法是使用 Validator::extend 函数注册定制的验证规则:
注册一个定制的验证规则
Validator::extend('foo', function($attribute, $value, $parameters)
return $value == 'foo';
注意: 传递给 extend 函数的规则的名字必须符合 "snake cased" 命名规则。
  定制的验证器接受三个参数:待验证属性的名字、待验证属性的值以及传递给这个规则的参数。
  您也可以传递一个类的函数到 extend 函数,而不是使用闭包:
  Validator::extend('foo', 'FooValidator@validate');
  注意您需要为您的定制规则定义错误消息。您既可以使用一个行内的定制消息数组,也可以在验证语言文件中进行添加。
  您也可以扩展 Validator 类本身,而不是使用闭包回调扩展验证器。为了实现这个目的,添加一个继承自 Illuminate\Validation\Validator 的验证器类。您可以添加在类中添加以 validate 开头的验证函数:
扩展验证器类
class CustomValidator extends Illuminate\Validation\Validator {
public function validateFoo($attribute, $value, $parameters)
return $value == 'foo';
下面,您需要注册定制的验证器扩展:
您需要注册定制的验证器扩展
Validator::resolver(function($translator, $data, $rules, $messages)
return new CustomValidator($translator, $data, $rules, $messages);
  当创建一个定制的验证规则,您有时需要为错误消息定义一个定制的占位符。为了实现它,您可以像上面那样创建一个定制的验证器,并且在验证器中添加一个 replaceXXX 函数:
protected function replaceFoo($message, $attribute, $rule, $parameters)
return str_replace(':foo', $parameters[0], $message);
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具}

我要回帖

更多关于 平特一肖中奖率高达90 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信