程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> Laravel4中的Validator驗證擴展用法詳解

Laravel4中的Validator驗證擴展用法詳解

編輯:PHP綜合

本文實例講述了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);
});

然後在rule中就可以使用mobile做為規則了。

這種擴展驗證規則放到哪裡呢?

我建議是在filters同級目錄下增加一個validator.php,然後再start/global.php中

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

輸出信息統一提示

上面的那個例子中,message和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自帶的驗證規則

更多關於Laravel相關內容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《smarty模板入門基礎教程》、《php日期與時間用法總結》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家基於Laravel框架的PHP程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved