首頁 後端開發 php教程 Laravel框架表单验证详解_PHP

Laravel框架表单验证详解_PHP

May 31, 2016 pm 07:29 PM
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', '

:message

');

  注意: 默认情况下,消息将使用与 Bootstrap 兼容的语法进行格式化。

  以某种格式获取所有错误消息

代码如下:


  foreach ($messages->all('

  • :message
  • ') 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 变量:

    代码如下:


    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,...

      仅当指定的域存在的时候,验证此规则的值必须存在。

    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

      验证此规则的值必须是一个合法的 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:
    :values',
      );


      有些时候,您可能希望只对一个指定的域指定定制的错误消息:

      对一个指定的域指定定制的错误消息

    代码如下:


    $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);
    }


    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    熱門話題

    Java教學
    1662
    14
    CakePHP 教程
    1419
    52
    Laravel 教程
    1313
    25
    PHP教程
    1262
    29
    C# 教程
    1235
    24
    laravel入門實例 laravel入門實例 Apr 18, 2025 pm 12:45 PM

    Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。

    解決 Craft CMS 中的緩存問題:使用 wiejeben/craft-laravel-mix 插件 解決 Craft CMS 中的緩存問題:使用 wiejeben/craft-laravel-mix 插件 Apr 18, 2025 am 09:24 AM

    在使用CraftCMS開發網站時,常常會遇到資源文件緩存的問題,特別是當你頻繁更新CSS和JavaScript文件時,舊版本的文件可能仍然被瀏覽器緩存,導致用戶無法及時看到最新的更改。這個問題不僅影響用戶體驗,還會增加開發和調試的難度。最近,我在項目中遇到了類似的困擾,經過一番探索,我找到了wiejeben/craft-laravel-mix這個插件,它完美地解決了我的緩存問題。

    laravel用戶登錄功能 laravel用戶登錄功能 Apr 18, 2025 pm 12:48 PM

    Laravel 提供了一個全面的 Auth 框架,用於實現用戶登錄功能,包括:定義用戶模型(Eloquent 模型)創建登錄表單(Blade 模板引擎)編寫登錄控制器(繼承 Auth\LoginController)驗證登錄請求(Auth::attempt)登錄成功後重定向(redirect)考慮安全因素:哈希密碼、防 CSRF 保護、速率限制和安全標頭。此外,Auth 框架還提供重置密碼、註冊和驗證電子郵件等功能。詳情請參閱 Laravel 文檔:https://laravel.com/doc

    Laravel和後端:為Web應用程序提供動力邏輯 Laravel和後端:為Web應用程序提供動力邏輯 Apr 11, 2025 am 11:29 AM

    Laravel是如何在後端邏輯中發揮作用的?它通過路由系統、EloquentORM、認證與授權、事件與監聽器以及性能優化來簡化和增強後端開發。 1.路由系統允許定義URL結構和請求處理邏輯。 2.EloquentORM簡化數據庫交互。 3.認證與授權系統便於用戶管理。 4.事件與監聽器實現松耦合代碼結構。 5.性能優化通過緩存和隊列提高應用效率。

    laravel框架安裝方法 laravel框架安裝方法 Apr 18, 2025 pm 12:54 PM

    文章摘要:本文提供了詳細分步說明,指導讀者如何輕鬆安裝 Laravel 框架。 Laravel 是一個功能強大的 PHP 框架,它 упростил 和加快了 web 應用程序的開發過程。本教程涵蓋了從系統要求到配置數據庫和設置路由等各個方面的安裝過程。通過遵循這些步驟,讀者可以快速高效地為他們的 Laravel 項目打下堅實的基礎。

    Laravel如何學習 怎麼免費學習Laravel Laravel如何學習 怎麼免費學習Laravel Apr 18, 2025 pm 12:51 PM

    想要學習 Laravel 框架,但苦於沒有資源或經濟壓力?本文為你提供了免費學習 Laravel 的途徑,教你如何利用網絡平台、文檔和社區論壇等資源,從入門到掌握,為你的 PHP 開發之旅奠定堅實基礎。

    laravel怎麼查看版本號 laravel查看版本號方法 laravel怎麼查看版本號 laravel查看版本號方法 Apr 18, 2025 pm 01:00 PM

    Laravel框架內置了多種方法來方便地查看其版本號,滿足開發者的不同需求。本文將探討這些方法,包括使用Composer命令行工具、訪問.env文件或通過PHP代碼獲取版本信息。這些方法對於維護和管理Laravel應用程序的版本控制至關重要。

    laravel有哪些版本 laravel新手版本選擇方法 laravel有哪些版本 laravel新手版本選擇方法 Apr 18, 2025 pm 01:03 PM

    在面向初学者的 Laravel 框架版本选择指南中,本文深入探討了 Laravel 的版本差異,旨在協助初學者在眾多版本之間做出明智的選擇。我們將重點介紹每個版本的關鍵特徵、比較它們的優缺點,並提供有用的建議,幫助新手根據他們的技能水準和項目需求挑選最合適的 Laravel 版本。對於初學者來說,選擇一個合適的 Laravel 版本至關重要,因為它可以顯著影響他們的學習曲線和整體開發體驗。

    See all articles