Spring Boot Validation

2026. 2. 7. 22:01·Spring/어노테이션
반응형


🏁 학습할 내용

  • 설치 방법
  • 어노테이션 종류
  • 주의 사항

⬇️ 설치

implementation("org.springframework.boot:spring-boot-starter-validation")

 

 

2️⃣ 어노테이션 종류

 

✅ 문자열(String) 관련

 

어노테이션 설명 예시
@NotBlank null, 빈 문자열, 공백만 있는 문자열 ❌ " " → 실패
@NotEmpty null ❌, 길이 0 ❌ (공백은 허용) "" → 실패
@NotNull null만 ❌ null → 실패
@Size(min, max) 문자열 길이 범위 제한 @Size(min=2, max=10)
@Pattern(regexp) 정규식 패턴 검사 이메일, 전화번호 등
@Email 이메일 형식 검사 test@email.com

 

🔢 숫자(Number) 관련

 

어노테이션 설명 예시
@NotNull null ❌  
@Min(value) 최소값 이상 @Min(0)
@Max(value) 최대값 이하 @Max(100)
@Positive 양수 (> 0)  
@PositiveOrZero 0 이상  
@Negative 음수 (< 0)  
@NegativeOrZero 0 이하  
@DecimalMin(value) 실수 최소값 "0.0"
@DecimalMax(value) 실수 최대값 "99.9"
@Digits(integer, fraction) 정수부/소수부 자릿수 제한 @Digits(integer=5, fraction=2)

 

📅 날짜/시간 관련

 

어노테이션 설명
@Past 과거 날짜만 허용
@PastOrPresent 과거 또는 현재
@Future 미래 날짜만 허용
@FutureOrPresent 현재 또는 미래

 

📦 컬렉션/배열 관련


어노테이션 설명
@NotEmpty null ❌, 비어있음 ❌
@Size(min, max) 요소 개수 제한

 

🎯 Boolean 관련

 

어노테이션 설명
@AssertFalse false 여야 통과
@AssertTrue true 여야 통과

 

🧩 Hibernate Validator 전용 (확장)


어노테이션 설명
@Range(min, max) 숫자 범위 제한 (@Min + @Max)
@Length(min, max) 문자열 길이 제한 (@Size와 유사)
@URL URL 형식 검사
@CreditCardNumber 카드 번호 형식 검사

⚠️ 주의사항

 

☕ JAVA가 아니라서..

 

다른 어노테이션은 @ABC로 편하게 썻지만, Bean Validation은 필드 기준으로 동작하고

코틀린의 기본 어노테이션 위치는 property 라서 검증 동작이 안 먹는 경우가 있음

 

그래서, 다음과 같이 써야함

class QuestionForm(
    @field:NotEmpty(message = "제목은 필수 항목입니다.")
    @field:Size(max = 200)
    val subject: String,

    @field:NotEmpty(message = "내용은 필수항목입니다.")
    val content: String
)

 

🔎 검증 결과는 반드시, @Valid 파라미터 뒤에

파라미터 @Valid를 붙히면 해당 클래스 안에 있는 Validation 어노테이션 검사가 동작한다.

이후, 그 결과가 BindingResult타입으로 전달되는데,  순서가 뒤에 있어야 정확한 검증 결과가 도착한다.

 

    @PostMapping("/create")
    fun questionCreate(
        @Valid questionForm: QuestionForm,
        bindingResult: BindingResult
    ): String {
        if (bindingResult.hasErrors()) {
            return "question_form"
        }

        questionService.create(questionForm.subject, questionForm.content)
        return "redirect:/question/list"
    }

 


출처

https://beanvalidation.org/

반응형

'Spring > 어노테이션' 카테고리의 다른 글

RequestParam  (0) 2026.01.17
Request 어노테이션  (0) 2026.01.17
@ResponseStatus  (0) 2026.01.10
@PathVariable  (0) 2026.01.10
@ResponseBody  (0) 2025.12.21
'Spring/어노테이션' 카테고리의 다른 글
  • RequestParam
  • Request 어노테이션
  • @ResponseStatus
  • @PathVariable
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (325) N
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (133) N
        • UIKit (37)
        • Combine (1)
        • SwiftUI (33) N
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (20)
        • 어노테이션 (6)
        • 튜토리얼 (13)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (9)
        • 이론 (9)
        • MCP (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    boostcamp
    UIKit
    dp
    concurrency
    Swift
    dfs
    protocol
    dispatch
    백준
    투포인터
    lifecycle
    Tuist
    CS
    AVFoundation
    property
    Spring
    SwiftUI
    GIT
    프로그래머스
    IOS
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
Spring Boot Validation
상단으로

티스토리툴바