Symfony-검증

검증은 애플리케이션을 설계하는 동안 가장 중요한 측면입니다. 들어오는 데이터의 유효성을 검사합니다. 이 장에서는 양식 유효성 검사에 대해 자세히 설명합니다.

검증 제약

유효성 검사기는 제약 조건에 대해 개체의 유효성을 검사하도록 설계되었습니다. 객체의 유효성을 검사하는 경우 하나 이상의 제약 조건을 해당 클래스에 매핑 한 다음 유효성 검사기 서비스에 전달하면됩니다. 기본적으로 객체의 유효성을 검사 할 때 해당 클래스의 모든 제약 조건이 실제로 통과하는지 여부를 확인합니다. Symfony는 다음과 같은 주목할만한 유효성 검사 제약을 지원합니다.

NotBlank

속성이 비어 있지 않은지 확인합니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 

class Student { 
   /** 
      * @Assert\NotBlank() 
   */ 
   protected $studentName; 
}

이 NotBlank 제약 조건은 studentName 속성이 비어 있지 않도록합니다.

NotNull

값이 null과 완전히 같지 않은지 확인합니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 

class Student { 
   /** 
      * @Assert\NotNull() 
   */ 
   protected $studentName; 
}

이메일

값이 유효한 이메일 주소인지 확인합니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 

class Student { 
   /** 
      * @Assert\Email( 
         * message = "The email '{{ value }}' is not a valid email.", 
         * checkMX = true 
      * ) 
   */ 
   protected $email; 
}

IsNull

값이 정확히 null과 같은지 확인합니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 

class Student { 
   /** 
      * @Assert\IsNull() 
   */ 
   protected $studentName; 
}

길이

주어진 문자열 길이가 최소값과 최대 값 사이에 있는지 확인합니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 

class Student { 
   /**
      * @Assert\Length( 
         * min = 5, 
         * max = 25, 
         * minMessage = "Your first name must be at least {{ limit }} characters long", 
         * maxMessage = "Your first name cannot be longer than {{ limit }} characters" 
      * ) 
   */ 
   protected $studentName; 
}

범위

주어진 숫자가 최소값과 최대 값 사이에 있는지 확인합니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 
class Student { 
   /** 
      * @Assert\Range( 
         * min = 40, 
         * max = 100, 
         * minMessage = "You must be at least {{ limit }} marks”, 
         * maxMessage = "Your maximum {{ limit }} marks” 
      * ) 
   */ 
   protected $marks; 
}

데이트

값이 유효한 날짜인지 확인합니다. 유효한 YYYY-MM-DD 형식을 따릅니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 

class Student { 
   /** 
      * @Assert\Date() 
   */ 
   protected $joinedAt; 
}

선택

이 제약 조건은 주어진 값이 주어진 유효한 선택 세트 중 하나인지 확인하는 데 사용됩니다. 또한 항목 배열의 각 항목이 유효한 선택 항목 중 하나인지 확인하는 데 사용할 수도 있습니다. 구문은 다음과 같습니다.

namespace AppBundle\Entity;  
use Symfony\Component\Validator\Constraints as Assert;  

class Student { 
   /** 
      * @Assert\Choice(choices = {"male", "female"}, message = "Choose a valid gender.") 
   */ 
   protected $gender; 
}

사용자 암호

이것은 입력 값이 현재 인증 된 사용자의 암호와 동일한 지 확인합니다. 이는 사용자가 비밀번호를 변경할 수 있지만 보안을 위해 이전 비밀번호를 입력해야하는 양식에서 유용합니다. 구문은 다음과 같습니다.

namespace AppBundle\Form\Model; 
use Symfony\Component\Security\Core\Validator\Constraints as SecurityAssert; 

class ChangePassword { 
   /** 
      * @SecurityAssert\UserPassword( 
         * message = "Wrong value for your current password" 
      * ) 
   */ 
   protected $oldPassword;
}

이 제약 조건은 이전 암호가 사용자의 현재 암호와 일치하는지 확인합니다.

검증 예

검증 개념을 이해하기 위해 간단한 애플리케이션 예제를 작성해 보겠습니다.

Step 1 − 검증 애플리케이션을 생성합니다.

Symfony 애플리케이션을 만듭니다. validationsample, 다음 명령을 사용합니다.

symfony new validationsample

Step 2 − 이름이 지정된 엔티티를 생성합니다. FormValidation 파일에 “FormValidation.php” 아래의 “src/AppBundle/Entity/”예배 규칙서. 파일에 다음 변경 사항을 추가하십시오.

FormValidation.php

<?php 
namespace AppBundle\Entity; 
use Symfony\Component\Validator\Constraints as Assert; 

class FormValidation {       
   /** 
      * @Assert\NotBlank() 
   */ 
   protected $name;  
      
   /** 
      * @Assert\NotBlank() 
   */ 
   protected $id;  
   protected $age;  
      
   /** 
      * @Assert\NotBlank() 
   */ 
   protected $address;  
   public $password;
      
   /** 
      * @Assert\Email( 
         * message = "The email '{{ value }}' is not a valid email.", 
         * checkMX = true 
      * ) 
   */ 
   protected $email;  
      
   public function getName() { 
      return $this->name; 
   }  
   public function setName($name) { 
      $this->name = $name; 
   }  
   public function getId() { 
      return $this->id; 
   } 
   public function setId($id) { 
      $this->id = $id; 
   }  
   public function getAge() { 
      return $this->age; 
   }  
   public function setAge($age) { 
      $this->age = $age;
   }  
   public function getAddress() { 
      return $this->address; 
   }  
   public function setAddress($address) { 
      $this->address = $address; 
   }  
   public function getEmail() { 
      return $this->email; 
   }  
   public function setEmail($email) { 
      $this->email = $email; 
   } 
}

Step 3 − 만들기 validateActionStudentController의 메서드. 디렉토리로 이동“src/AppBundle/Controller”, 창조하다 “studentController.php” 파일에 다음 코드를 추가하십시오.

StudentController.php

use AppBundle\Entity\FormValidation; 
/** 
   * @Route("/student/validate") 
*/ 
public function validateAction(Request $request) { 
   $validate = new FormValidation(); 
   $form = $this->createFormBuilder($validate) 
      ->add('name', TextType::class)
      ->add('id', TextType::class) 
      ->add('age', TextType::class) 
      ->add('address', TextType::class) 
      ->add('email', TextType::class) 
      ->add('save', SubmitType::class, array('label' => 'Submit')) 
      ->getForm();  
      
   $form->handleRequest($request);  
   if ($form->isSubmitted() && $form->isValid()) { 
      $validate = $form->getData(); 
      return new Response('Form is validated.'); 
   }  
   return $this->render('student/validate.html.twig', array( 
      'form' => $form->createView(), 
   )); 
}

여기서는 Form 클래스를 사용하여 양식을 만든 다음 양식을 처리했습니다. 양식이 제출되고 유효한 경우 양식 유효성 검사 메시지가 표시됩니다. 그렇지 않으면 기본 양식이 표시됩니다.

Step 4− 위에서 생성 된 액션에 대한 뷰를 StudentController에 생성합니다. 디렉토리로 이동“app/Resources/views/student/”. 창조하다“validate.html.twig” 파일에 다음 코드를 추가하십시오.

{% extends 'base.html.twig' %} 
{% block stylesheets %} 
   <style> 
      #simpleform { 
         width:600px; 
         border:2px solid grey; 
         padding:14px; 
      }  
      #simpleform label {
         font-size:14px; 
         float:left; 
         width:300px; 
         text-align:right; 
         display:block; 
      }  
      #simpleform span { 
         font-size:11px; 
         color:grey; 
         width:100px; 
         text-align:right; 
         display:block; 
      }  
      #simpleform input { 
         border:1px solid grey; 
         font-family:verdana; 
         font-size:14px; 
         color:light blue; 
         height:24px; 
         width:250px; 
         margin: 0 0 10px 10px; 
      }  
      #simpleform textarea { 
         border:1px solid grey; 
         font-family:verdana; 
         font-size:14px; 
         color:light blue; 
         height:120px; 
         width:250px; 
         margin: 0 0 20px 10px;
      }  
      #simpleform select { 
         margin: 0 0 20px 10px; 
      }  
      #simpleform button { 
         clear:both; 
         margin-left:250px; 
         background: grey; 
         color:#FFFFFF; 
         border:solid 1px #666666; 
         font-size:16px; 
      } 
   </style> 
{% endblock %}  

{% block body %} 
   <h3>Student form validation:</h3> 
   <div id = "simpleform"> 
      {{ form_start(form) }} 
      {{ form_widget(form) }} 
      {{ form_end(form) }} 
   </div>   
{% endblock %}

여기에서는 양식 태그를 사용하여 양식을 작성했습니다.

Step 5 − 마지막으로 응용 프로그램을 실행하고 http://localhost:8000/student/validate.

결과 : 초기 페이지

결과 : 최종 페이지