這次帶給大家Laravel中unique和exists驗證規則優化步驟詳解,Laravel中unique和exists驗證規則優化的注意事項有哪些,以下就是實戰案例,一起來看一下。
前言
Laravel提供了多種方法來驗證應用輸入資料。預設情況下,Laravel的控制器基底類別使用ValidatesRequests trait,該trait提供了便利的方法透過各種強大的驗證規則來驗證輸入的HTTP請求。
Laravel中透過ValidatesRequests這個trait來驗證requests非常的方便,並且在BaseController類別中它被自動的引入了。 exitsts()和unique()這兩個規則非常的強大和便利。
它們在使用的過程中需要對資料庫中已有的資料進行驗證,通常它們會像下面這樣來寫:
// exists example 'email' => 'exists:staff,account_id,1' // unique example 'email' => 'unique:users,email_address,$user->id,id,account_id,1'
上面這種寫法的語法很難記,我們幾乎每次使用時,都必須去查詢一下文件。但從 Laravel 的5.3.18版本開始這兩個驗證規則都可以透過一個新的Rule類別來簡化。
我們現在可以使用下面這樣的熟悉的鍊式語法來達到相同的效果:
'email' => [ 'required', Rule::exists('staff')->where(function ($query) { $query->where('account_id', 1); }), ],
'email' => [ 'required', Rule::unique('users')->ignore($user->id)->where(function ($query) { $query->where('account_id', 1); }) ],
這兩個驗證規則也都支援下面的鍊式方法:
where
whereNot
#whereNull
protected function formatWheres() { return collect($this->wheres)->map(function ($where) { return $where['column'].','.$where['value']; })->implode(','); }
以上是Laravel中unique與exists驗證規則最佳化步驟詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!