머리말
이 글에서는 Laravel에서 요청 유효성 검사 작성에 대한 내용을 주로 소개합니다. laravel로 API를 작성할 때 프런트 엔드에서 전달되는 요청이 POST/PUT/PATH 및 기타 방법일 경우 검증을 요청해야 합니다. 프런트엔드와 백엔드 분리 프로그램의 경우 프런트엔드 프로그램 Angular/Vue가 이미 검증을 수행했지만 ajax가 전달한 json 입력도 백엔드에서 검증해야 합니다.
그럼 요청 유효성 검사를 우아하게 작성하는 방법은 무엇일까요? Laravel 공식 문서에는 이미 이 기능이 포함되어 있습니다: Form Request Validation
구현 방법은 다음과 같습니다
여기서 JsonRequest를 작성할 수 있습니다:
class JsonRequest extends Illuminate\Foundation\Http\FormRequest { public function rules() { $method = $this->method(); assert(in_array($method, [static::METHOD_POST, static::METHOD_PUT, static::METHOD_PATCH], true)); $controller = $this->route()->getController(); $rules = $controller::RULES; return ($rules[$this->method()] ?? []) + ($rules['*'] ?? []); } public function authorize() { return true; } }
이 방법으로 다음과 같은 많은 모델 컨트롤러에서 JsonRequest를 사용할 수 있습니다:
use Illuminate\Http\Request; final class AccountController extends \App\Http\Controllers\Controller { public const RULES = [ Request::METHOD_POST => [ 'bank_account' => 'required_if:type,bank', 'loan_account' => 'required_if:type,loan', ], Request::METHOD_PUT => [ // ... ], '*' => [ // ... ], ]; }
이렇게 하면 프런트 엔드에서 전달된 json 입력이 올바른지 확인할 수 있습니다.
(1) 프런트 엔드에서 전달된 json 입력이
{ "name": "lx1036", "type": "loan", "bank_account": { "source": "bank", } }
인 경우 유효성 검사가 실패하고 불법입니다.
(2) 프런트 엔드에서 전달된 json 입력이
{ "name": "lx1036", "type": "bank", "loan_account": { "source": "loan", } }
인 경우 유효성 검사가 실패하고 불법입니다.
이러한 방식으로 json 입력을 확인할 수 있습니다. 불법인 경우 HttpException이 직접 발생하며 이는 더 이상 로직의 다음 단계를 입력하는 데 사용되지 않습니다. 이러한 중첩된 json 입력의 경우 요청 유효성 검사를 사용하여 개체 간의 관계를 확인하는 것이 중요합니다. 이는 핵심 비즈니스 논리에 들어가기 전 예비 확인으로 간주될 수 있습니다. . 물론 마지막에 테이블을 작성할 때 잘못된 데이터가 DB에 들어가는 것을 방지하기 위해 모델 유효성 검사가 있습니다.
마지막으로 laravel 문서에서는 사용법에 대해서만 설명하고 원리는 설명하지 않습니다. 코드는 IlluminateFoundationProvidersFormRequestServiceProvider::class:
public function boot() { // \Illuminate\Foundation\Http\FormRequest use 了 ValidatesWhenResolvedTrait,extends 了 \Illuminate\Contracts\Validation\ValidatesWhenResolved $this->app->afterResolving(ValidatesWhenResolved::class, function ($resolved) { $resolved->validate(); }); // ... }
에 있으므로 IlluminateFoundationHttpFormRequest가 컨테이너에서 해결되면 IlluminateFoundationHttpFormRequest::validate() 메서드가 즉시 실행됩니다. 자세한 내용은 아니지만 laravel 소스 코드를 볼 수 있습니다.
요컨대, 프로그램을 작성할 때 요청 유효성 검사 및 모델 유효성 검사를 포함하여 유효성 검사가 매우 중요하므로 작성해야 합니다. . .
요약
위 내용은 Laravel의 쓰기 요청 유효성 검사에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!