您好,登錄后才能下訂單哦!
這篇文章主要介紹“Laravel如何自定義驗證對象”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Laravel如何自定義驗證對象”文章能幫助大家解決問題。
Laravel 5.5 將提供一個全新的自定義驗證規則的對象,以作為原來的 Validator::extend 方法的替代。很多時候我們會直接用正則表達式來處理這種特殊的驗證,也有時候我們會選擇用 Validator::extend 來擴展一個自定義的規則。但在 Laravel 5.5 版本中,我們有了新的手段,只要定義一個實現 Illuminate\Contracts\Validation\Rule 接口的類即可實現自定義的驗證規則,并可以直接使用。
下面是一個簡單的示例:
use Illuminate\Contracts\Validation\Rule; class IsOddValidationRule implements Rule { public function passes($attributes, $value) { return ($value % 2 !== 0); } public function message() { return ':attribute 必須是奇數'; } }
以上代碼定義了一個 IsOddValidationRule 的自定義驗證類,在 Controller 中要使用這個驗證類的話,可以這樣寫:
public function handlForm(Request $request) { $this->validate($request, [ 'oddField' => [new IsOddValidationRule] ]); }
同樣的效果,也可以通過匿名函數(閉包函數)來實現:
public function handleForm(Request $request) { $this->validate($request, [ 'oddField' => [function($attributes, $value, $fail) { if ($value % 2 === 0) { $fail(':attribute 必須是奇數!'); } }] ]); }
在驗證的表單項為空值或者不存在的時候,對應的自定義驗證規則不會執行。這個與系統自帶的驗證規則的邏輯是一致的。如果你希望你的自定義驗證規則,即使是在對應的表單項為空值時也被執行的話,那么只要把繼承的接口從 rule 改成 ImplicitRule 即可:
class IsOddValidationRule implements ImplicitRule { ... }
采用 Laravel 5.5 新增的自定義驗證類,可以更好地管理大量的自定義驗證規則,而且在 PHPStorm 之類的 IDE 中,從驗證代碼里快速跳轉到對應的驗證類的代碼也會更方便。畢竟采用 Validator::extend 的話,你只能通過搜索對應驗證類名稱的字符串來找到規則定義的源代碼。
匿名函數的自定義驗證規則在一次性的簡單驗證邏輯中用起來確實會很方便,或者是在編碼過程中快速測試驗證邏輯也很實用。但是總的來說,還是建議采用更具組織性和可讀性的自定義驗證類。最佳方法是在編寫 Controller 的過程中用匿名函數快速驗證自定義規則,然后再把它移到自定義的驗證類對象中。
Laravel 是一套簡潔、優雅的PHP Web開發框架。它可以讓你從面條一樣雜亂的代碼中解脫出來;它可以幫你構建一個完美的網絡APP,而且每行代碼都可以簡潔、富于表達力。
關于“Laravel如何自定義驗證對象”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。