스프링 MVC 2편(백엔드 웹 개발 활용 기술)

Ch05. 검증(Bean Validation) - Bean Validation(스프링 적용)

webmaster 2022. 3. 16. 10:30
728x90
@PostMapping("/add")
public String addItem(@Validated @ModelAttribute Item item, BindingResult bindingResult,
    RedirectAttributes redirectAttributes, Model model) { //@Validated를 적어주면 정상적으로 어노테이션이 동작한다
    //@Validated가 있으면 글로벌 Validator가 동작해서 어노테이션 기반 검증을 한다
    if (bindingResult.hasErrors()) {
        log.info("bindingResult = {}", bindingResult);
        return "validation/v3/addForm";
    }

    //성공 로직
    Item savedItem = itemRepository.save(item);
    redirectAttributes.addAttribute("itemId", savedItem.getId());
    redirectAttributes.addAttribute("status", true);
    return "redirect:/validation/v3/items/{itemId}";
}

 

  • 이전 코드와 동일하게 사용하여도 자동으로 어노테이션으로 등록한 Validation이 동작한다.
  • 스프링 부트가 spring-boot-starter-validation 라이브러리를 넣으면 자동으로 Bean Validator를 인지하고 스프링에 통합한다.
  • 스프링 부트는 자동으로 글로벌 Validator로 등록한다.
    • LocalValidatorFactoryBean을 글로벌 Validator로 등록한다. 이 Validator는 @NotNull 같은 애노테이션을 보고 검증을 수행한다. 이렇게 글로벌 Validator가 적용되어 있기 때문에, @Valid , @Validated 만 적용하면 된다. 검증 오류가 발생하면, FieldError , ObjectError를 생성해서 BindingResult에 담아준다.
  • 참고
    • 검증시 @Validated @Valid 둘 다 사용 가능하다.
    • javax.validation.@Valid를 사용하려면 build.gradle 의존관계 추가가 필요하다. (이전에 추가했다.) 
      • implementation 'org.springframework.boot:spring-boot-starter-validation' 
    • @Validated는 스프링 전용 검증 애노테이션이고, @Valid 는 자바 표준 검증 애노테이션이다. 둘중 아무거나 사용해도 동일하게 작동하지만, @Validated 는 내부에 groups라는 기능을 포함하고 있다. 이 부분은 조금 뒤에 다시 설명하겠다
  • 검증 순서
    • @ModelAttribute 각각의 필드에 타입 변환 시도
      • 성공하면 다음으로 
      • 실패하면 typeMismatch로 FieldError 추가
    • Validator 적용
    • 바인딩에 성공한 필드만 Bean Validation 적용 BeanValidator는 바인딩에 실패한 필드는 BeanValidation을 적용하지 않는다. 생각해보면 타입 변환에 성공해서 바인딩에 성공한 필드여야 BeanValidation 적용이 의미 있다. (일단 모델 객체에 바인딩받는 값이 정상으로 들어와야 검증도 의미가 있다.)
    • @ModelAttribute -> 각각의 필드 타입 변환 시도 -> 변환에 성공한 필드만 BeanValidation 적용
728x90