首先說下原理,表單驗證使用validate驗證器進行驗證,如果表單驗證不通過,將表單數據和錯誤信息閃存到session中去,然后再到表單中進行展示。
1.驗證器規則的寫法,返回一個規則數組
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
public function rule() { return [ 'name' => [ 'required' , 'max: 5' , 'min: 2' , 'regex: /^[\x{4e00}-\x{9fa5}A-Za-z0-9_]+$/u' ], 'password' => [ 'required' , 'min: 6' , 'max: 12' , ], ]; } |
執行下面這句話,生成一個驗證器,默認會將錯誤信息保存到session中,自動重定向到跳轉到之前頁面;
1
|
$this ->validate( $request , $this ->rule()); |
這時返回的頁面沒有獲取到舊的頁面提交的數據,需要閃存表單數據到session中去,不過要將這段語句放在上面那段話之前,因為上面的語句執行發現錯誤了之后,默認直接跳轉到之前的頁面。
1
2
|
$request ->flashOnly([ 'name' , 'password' ]); // 這是只閃存name和password的意思 // $request->flash(); // 閃存表單的所有數據到session中去 |
顯示錯誤信息的代碼如下:
1
2
3
4
5
6
7
8
9
|
@ if ( count ( $errors ) > 0) <div class = "alert alert-danger" > <ul> @ foreach ( $errors ->all() as $error ) <li>{{ $error }}</li> @ endforeach </ul> </div> @ endif |
如果在控制器中,有錯誤的信息,需要跳轉到之前的頁面,也可以使用以下代碼:
1
|
return back()->withErrors( '更新圖片信息失敗' ); |
同樣會在之前的頁面顯示錯誤信息。
以上這篇laravel5.2表單驗證,并顯示錯誤信息的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/qq_21885337/article/details/81139565