Laravel 5.5 中怎么自定義驗證對象,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
為翔安等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及翔安網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站設(shè)計、成都網(wǎng)站制作、翔安網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!Laravel 5.5 將提供一個全新的自定義驗證規(guī)則的對象,以作為原來的 Validator::extend 方法的替代。很多時候我們會直接用正則表達式來處理這種特殊的驗證,也有時候我們會選擇用 Validator::extend 來擴展一個自定義的規(guī)則。但在 Laravel 5.5 版本中,我們有了新的手段,只要定義一個實現(xiàn) Illuminate\Contracts\Validation\Rule 接口的類即可實現(xiàn)自定義的驗證規(guī)則,并可以直接使用。
下面是一個簡單的示例:
use Illuminate\Contracts\Validation\Rule; class IsOddValidationRule implements Rule { public function passes($attributes, $value) { return ($value % 2 !== 0); } public function message() { return ':attribute 必須是奇數(shù)'; } }
以上代碼定義了一個 IsOddValidationRule 的自定義驗證類,在 Controller 中要使用這個驗證類的話,可以這樣寫:
public function handlForm(Request $request) { $this->validate($request, [ 'oddField' => [new IsOddValidationRule] ]); }
同樣的效果,也可以通過匿名函數(shù)(閉包函數(shù))來實現(xiàn):
public function handleForm(Request $request) { $this->validate($request, [ 'oddField' => [function($attributes, $value, $fail) { if ($value % 2 === 0) { $fail(':attribute 必須是奇數(shù)!'); } }] ]); }
在驗證的表單項為空值或者不存在的時候,對應(yīng)的自定義驗證規(guī)則不會執(zhí)行。這個與系統(tǒng)自帶的驗證規(guī)則的邏輯是一致的。如果你希望你的自定義驗證規(guī)則,即使是在對應(yīng)的表單項為空值時也被執(zhí)行的話,那么只要把繼承的接口從 rule 改成 ImplicitRule 即可:
class IsOddValidationRule implements ImplicitRule { ... }
采用 Laravel 5.5 新增的自定義驗證類,可以更好地管理大量的自定義驗證規(guī)則,而且在 PHPStorm 之類的 IDE 中,從驗證代碼里快速跳轉(zhuǎn)到對應(yīng)的驗證類的代碼也會更方便。畢竟采用 Validator::extend 的話,你只能通過搜索對應(yīng)驗證類名稱的字符串來找到規(guī)則定義的源代碼。
匿名函數(shù)的自定義驗證規(guī)則在一次性的簡單驗證邏輯中用起來確實會很方便,或者是在編碼過程中快速測試驗證邏輯也很實用。但是總的來說,還是建議采用更具組織性和可讀性的自定義驗證類。很好方法是在編寫 Controller 的過程中用匿名函數(shù)快速驗證自定義規(guī)則,然后再把它移到自定義的驗證類對象中。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,的支持。