Laravel4中的Validator驗證擴展用法詳解
本文實例講述了Laravel4中的Validator驗證擴展用法。分享給大家供大家參考,具體如下:
不管寫接口還是寫web頁面,實質(zhì)都是傳入?yún)?shù),然后進(jìn)行業(yè)務(wù)邏輯,然后再輸出具體內(nèi)容。所以,對參數(shù)的驗證是不可避免的一個環(huán)節(jié),比如傳過來的email是不是為空,是不是合法的email格式?laravel已經(jīng)為phper想到簡化這種邏輯的辦法了。就是Validator。
Validator的使用
制造一個驗證器
validator使用Validator::make可以制造一個驗證器。然后使用驗證器判斷傳入的參數(shù)是否是合法的。
看make的定義:
$data是keyvalue的要驗證的數(shù)據(jù)
$rules是驗證的規(guī)則
$messages是提示信息
$customAttributes是設(shè)置屬性別名的
其中后兩個消息都是為了提示信息而設(shè)置的
直接看一個例子,理解了就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");
}
在這個例子中
如果你傳遞的參數(shù)為
/index?name=12321321321321321321321
會返回:
{
show_warning: "電子郵件 不能為空"
}
Input::all() 將所有參數(shù)傳入進(jìn)行驗證
rule規(guī)定了email字段不能為空,它必須符合email的格式。rule規(guī)定了email字段不能為空,它必須符合email的格式。message 說明如果違反required規(guī)則的話,顯示錯誤的格式為:“:attribute 不能為空”
$attributes 說明了顯示的錯誤中email顯示為文字“電子郵件”
上面幾個設(shè)置加起來就導(dǎo)致了最后參數(shù)沒傳email的時候顯示的錯誤信息為:
“電子郵件 不能為空”
Validator的驗證擴展
驗證規(guī)則擴展
你一定會遇到比如要驗證是否手機號合法的問題,laravel的Validator沒有提供手機號驗證的規(guī)則,因為每個國家的手機號規(guī)則是不統(tǒng)一的。
但是這個使用想使用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做為規(guī)則了。
這種擴展驗證規(guī)則放到哪里呢?
我建議是在filters同級目錄下增加一個validator.php,然后再start/global.php中
require app_path().'/validator.php';
輸出信息統(tǒng)一提示
上面的那個例子中,message和message和attribute都需要在使用validator的時候自己定義,比較麻煩,有沒有更好的方法能統(tǒng)一設(shè)置呢?
validator的提示設(shè)置是按照語言來進(jìn)行設(shè)置的。
語言設(shè)置是config目錄下的app.php里面的locale界定的。默認(rèn)為en。
而en對應(yīng)的錯誤提示都在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在顯示的時候會被替換成對應(yīng)屬性名稱,attributes是設(shè)置屬性的中文名字的。
從這里也就看出來了laravel對跨語言的支持是什么樣子的。
lang下面的文件夾除了validation.php之外還有分頁:pagination.php,提示:reminders.php文件。
laravel自帶了哪些rule規(guī)則呢?
查看手冊吧。。。laravel自帶的驗證規(guī)則
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php日期與時間用法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設(shè)計有所幫助。
- Laravel關(guān)聯(lián)模型中過濾結(jié)果為空的結(jié)果集(has和with區(qū)別)
- laravel框架實現(xiàn)為 Blade 模板引擎添加新文件擴展名操作示例
- Laravel Intervention/image圖片處理擴展包的安裝、使用與可能遇到的坑詳解
- Laravel中基于Artisan View擴展包創(chuàng)建及刪除應(yīng)用視圖文件的方法
- 關(guān)于擴展 Laravel 默認(rèn) Session 中間件導(dǎo)致的 Session 寫入失效問題分析
- laravel容器延遲加載以及auth擴展詳解
- Laravel中擴展Memcached緩存驅(qū)動實現(xiàn)使用阿里云OCS緩存
- Laravel框架中擴展函數(shù)、擴展自定義類的方法
- laravel框架實現(xiàn)敏感詞匯過濾功能示例
相關(guān)文章
PHP表單數(shù)據(jù)寫入MySQL數(shù)據(jù)庫的代碼
這篇文章主要介紹了PHP表單數(shù)據(jù)寫入MySQL數(shù)據(jù)庫的相關(guān)資料非常不錯具有參考借鑒價值,需要的朋友可以參考下2016-05-05
Zend Framework教程之Zend_Helpers動作助手ViewRenderer用法詳解
這篇文章主要介紹了Zend Framework教程之Zend_Helpers動作助手ViewRenderer用法,結(jié)合實例形式較為詳細(xì)的分析了Zend_Helpers動作助手ViewRenderer的功能、使用方法與相關(guān)注意事項,需要的朋友可以參考下2016-07-07
PHP兩個n位的二進(jìn)制整數(shù)相加問題的解決
這篇文章主要為大家詳細(xì)介紹了PHP兩個n位的二進(jìn)制整數(shù)相加問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-08-08

