標籤:
本文和大家分享的主要是Laravel 5.5 的自訂驗證對象/類相關內容,一起來看看吧,希望對大家學習Laravel有所協助。 Laravel 5.5 將提供一個全新的自訂驗證規則的對象,以作為原來的 Validator::extend 方法的替代。 Laravel 中的表單驗證是比較方便的,而且內建了大量的可用驗證規則,但不管官方提供了多少,總還是會有滿足不了需求的時候。很多時候我們會直接用Regex來處理這種特殊的驗證,也有時候我們會選擇用 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 5.5 的自訂驗證對象/類