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.