>백엔드 개발 >PHP 튜토리얼 >Laravel의 쓰기 요청 유효성 검사에 대한 자세한 설명

Laravel의 쓰기 요청 유효성 검사에 대한 자세한 설명

黄舟
黄舟원래의
2017-10-26 10:32:411520검색

머리말

이 글에서는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.