이번에는 Laravel의 고유 및 존재 유효성 검사 규칙에 대한 최적화 단계에 대해 자세히 설명합니다. Laravel의 고유 및 존재 유효성 검사 규칙을 최적화하기 위한 주의사항은 무엇입니까? 다음은 실제 사례를 살펴보겠습니다.
머리말Laravel은 애플리케이션 입력 데이터의 유효성을 검사하는 다양한 방법을 제공합니다. 기본적으로 Laravel의
Controller기본 클래스는 다양하고 강력한 검증 규칙을 통해 들어오는 HTTP 요청을 검증하는 편리한 방법을 제공하는 ValidatesRequests 특성을 사용합니다. Laravel의 ValidatesRequests 특성을 통해 요청을 확인하는 것은 매우 편리하며 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); }) ],
두 유효성 검사 규칙 모두 다음 연결 방법도 지원합니다. whereNotNull
좋은 소식은 기존 쓰기 방식이 여전히 완벽하게 지원되며, 새로운 쓰기 방식은 실제로 하단의 formatWheres 메소드를 통해 기존 쓰기 방식으로 변환된다는 것입니다:
protected function formatWheres() { return collect($this->wheres)->map(function ($where) { return $where['column'].','.$where['value']; })->implode(','); }
추천 도서:
PHP에서 foreach를 사용하여 배열을 변환하는 단계에 대한 자세한 설명
위 내용은 Laravel의 고유하고 존재하는 유효성 검사 규칙에 대한 최적화 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!