不管寫接口還是寫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的格式。 \)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和\)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自帶的驗證規則