php表单验证详解,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)
{
//
}
获取全部域的全部错误消息
validation框架foreach ($messages->all() as $message)
{
//
}
检查⼀个域是否存在消息
if ($messages->has('email'))
{
//
}
以某种格式获取⼀条错误消息
echo $messages->first('email', '
:message
');
注意: 默认情况下,消息将使⽤与 Bootstrap 兼容的语法进⾏格式化。
以某种格式获取所有错误消息
foreach ($messages->all('
:message') as $message)
{
//
}
错误消息 & 视图
⼀旦您执⾏了验证,您需要⼀种简单的⽅法向视图反馈错误消息。这在 Lavavel 中能够⽅便的处理。以下⾯的路由作为例⼦:Route::get('register', function()
{
return View::make('ister');
});
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'); ?>
可⽤的验证规则
下⾯是⼀个所有可⽤的验证规则的列表以及它们的功能:
Accepted
Active URL
After (Date)
Alpha
Alpha Dash
Alpha Numeric
Before (Date)
Between
Confirmed
Date
Date Format
Different
E-Mail
Exists (Database)
Image (File)
In
Integer
IP Address
Max
MIME Types
Min
Not In
Numeric
Regular Expression
Required
Required If
Required With
Required Without
Same
Size
Unique (Database)
accepted
验证此规则的值必须是 yes、 on 或者是 1。这在验证是否同意"服务条款"的时候⾮常有⽤。
active_url
验证此规则的值必须是⼀个合法的 URL,根据 PHP 函数 checkdnsrr。
after:date
验证此规则的值必须在给定⽇期之后,⽇期将通过 PHP 函数 strtotime 传递。
alpha
验证此规则的值必须全部由字母字符构成。
alpha_dash
验证此规则的值必须全部由字母、数字、中划线或下划线字符构成。
alpha_num
验证此规则的值必须全部由字母和数字构成。
before:date
验证此规则的值必须在给定⽇期之前,⽇期将通过 PHP 函数 strtotime 传递。
between:min,max
验证此规则的值必须在给定的 min 和 max 之间。字符串、数字以及⽂件都将使⽤⼤⼩规则进⾏⽐较。
confirmed
验证此规则的值必须和 foo_confirmation 的值相同。⽐如,需要验证此规则的域是 password,那么在输⼊中必须有⼀个与之相同的password_confirmation 域。
date
验证此规则的值必须是⼀个合法的⽇期,根据 PHP 函数 strtotime。
date_format:format
验证此规则的值必须符合给定的 format 的格式,根据 PHP 函数 date_parse_from_format。
different:field
验证此规则的值必须与指定的 field 域的值不同。
email
验证此规则的值必须是⼀个合法的电⼦邮件地址。
exists:table,column
验证此规则的值必须在指定的数据库的表中存在。
Exists 规则的基础使⽤
'state' => 'exists:states'
指定列名
'state' => 'exists:states,abbreviation'
您也可以指定更多的条件,将以 "where" 的形式添加到查询。
'email' => 'exists:staff,email,account_id,1'
image
验证此规则的值必须是⼀个图⽚ (jpeg, png, bmp 或者 gif)。
in:foo,bar,...
验证此规则的值必须在给定的列表中存在。
integer
验证此规则的值必须是⼀个整数。
验证此规则的值必须是⼀个合法的 IP 地址。
max:value
验证此规则的值必须⼩于最⼤值 value。字符串、数字以及⽂件都将使⽤⼤⼩规则进⾏⽐较。
mimes:foo,bar,...
验证此规则的⽂件的 MIME 类型必须在给定的列表中。
MIME 规则的基础使⽤
'photo' => 'mimes:jpeg,bmp,png'
min:value
验证此规则的值必须⼤于最⼩值 value。字符串、数字以及⽂件都将使⽤⼤⼩规则进⾏⽐较。
not_in:foo,bar,...
验证此规则的值必须在给定的列表中不存在。
numeric
验证此规则的值必须是⼀个数字。
regex:pattern
验证此规则的值必须符合给定的正则表达式。
注意: 当使⽤ regex 模式的时候,有必要使⽤数组指定规则,⽽不是管道分隔符,特别是正则表达式中包含⼀个管道字符的时候。required
验证此规则的值必须在输⼊数据中存在。
required_if:field,value
当指定的域为某个值的时候,验证此规则的值必须存在。
required_with:foo,bar,...
仅当指定的域存在的时候,验证此规则的值必须存在。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论