欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Laravel4中的Validator驗(yàn)證擴(kuò)展用法詳解

 更新時(shí)間:2016年07月26日 12:01:25   作者:軒脈刃  
這篇文章主要介紹了Laravel4中的Validator驗(yàn)證擴(kuò)展用法,實(shí)例分析了Laravel4中的Validator驗(yàn)證器的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Laravel4中的Validator驗(yàn)證擴(kuò)展用法。分享給大家供大家參考,具體如下:

不管寫接口還是寫web頁面,實(shí)質(zhì)都是傳入?yún)?shù),然后進(jìn)行業(yè)務(wù)邏輯,然后再輸出具體內(nèi)容。所以,對參數(shù)的驗(yàn)證是不可避免的一個(gè)環(huán)節(jié),比如傳過來的email是不是為空,是不是合法的email格式?laravel已經(jīng)為phper想到簡化這種邏輯的辦法了。就是Validator。

Validator的使用

制造一個(gè)驗(yàn)證器

validator使用Validator::make可以制造一個(gè)驗(yàn)證器。然后使用驗(yàn)證器判斷傳入的參數(shù)是否是合法的。

看make的定義:

復(fù)制代碼 代碼如下:
public Validator make(array $data, array $rules, array $messages = array(), array $customAttributes = array())

$data是keyvalue的要驗(yàn)證的數(shù)據(jù)

$rules是驗(yàn)證的規(guī)則

$messages是提示信息

$customAttributes是設(shè)置屬性別名的

其中后兩個(gè)消息都是為了提示信息而設(shè)置的

直接看一個(gè)例子,理解了就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");
}

在這個(gè)例子中

如果你傳遞的參數(shù)為

/index?name=12321321321321321321321

會(huì)返回:

{
  show_warning: "電子郵件 不能為空"
}

Input::all() 將所有參數(shù)傳入進(jìn)行驗(yàn)證
rule規(guī)定了email字段不能為空,它必須符合email的格式。rule規(guī)定了email字段不能為空,它必須符合email的格式。message 說明如果違反required規(guī)則的話,顯示錯(cuò)誤的格式為:“:attribute 不能為空”
$attributes 說明了顯示的錯(cuò)誤中email顯示為文字“電子郵件”

上面幾個(gè)設(shè)置加起來就導(dǎo)致了最后參數(shù)沒傳email的時(shí)候顯示的錯(cuò)誤信息為:

“電子郵件 不能為空”

Validator的驗(yàn)證擴(kuò)展

驗(yàn)證規(guī)則擴(kuò)展

你一定會(huì)遇到比如要驗(yàn)證是否手機(jī)號(hào)合法的問題,laravel的Validator沒有提供手機(jī)號(hào)驗(yàn)證的規(guī)則,因?yàn)槊總€(gè)國家的手機(jī)號(hào)規(guī)則是不統(tǒng)一的。

但是這個(gè)使用想使用Validator做驗(yàn)證怎么辦呢?

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做為規(guī)則了。

這種擴(kuò)展驗(yàn)證規(guī)則放到哪里呢?

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

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

輸出信息統(tǒng)一提示

上面的那個(gè)例子中,message和message和attribute都需要在使用validator的時(shí)候自己定義,比較麻煩,有沒有更好的方法能統(tǒng)一設(shè)置呢?

validator的提示設(shè)置是按照語言來進(jìn)行設(shè)置的。

語言設(shè)置是config目錄下的app.php里面的locale界定的。默認(rèn)為en。

而en對應(yīng)的錯(cuò)誤提示都在lang目錄下的en目錄里面的validation.php中設(shè)置。

你可以看一眼lang/en/validation.php 就明白對應(yīng)的英文提示信息怎么出來的了。

要設(shè)置中文提示:

① 修改config/app.php里面的locale,設(shè)置為ch
② 創(chuàng)建 lang/ch/validation.php
③ 修改validation.php文件,將里面的提示信息修改為中文,注意提示信息中的:attribute在顯示的時(shí)候會(huì)被替換成對應(yīng)屬性名稱,attributes是設(shè)置屬性的中文名字的。

從這里也就看出來了laravel對跨語言的支持是什么樣子的。

lang下面的文件夾除了validation.php之外還有分頁:pagination.php,提示:reminders.php文件。

laravel自帶了哪些rule規(guī)則呢?

查看手冊吧。。。laravel自帶的驗(yàn)證規(guī)則

更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php日期與時(shí)間用法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家基于Laravel框架的PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評論