inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

errors.properties와 검증 애너테이션을 함께 사용할 때 적용되는 메시지

해결된 질문

652

HyunRian

작성한 질문수 2

0

안녕하세요, 수업을 다 듣고 따로 프로젝트를 생성하여

에러 메시지를 errors.properties에서 작성한 후 적용 여부를 확인해봤는데

적용이 되지 않아 질문드립니다.

 

  1. 프로젝트 환경

Spring Boot 3.2.1 / Java 17 / Jar Packaging / IntelliJ IDEA 입니다.

 

  1. 설정 및 작성 코드

스크린샷 2024-01-16 오후 3.38.17.png

 

spring.messages.basename=messages,errors

 

#추가(스프링이 생성한 기본 오류 메시지 코드 설정하기)
typeMismatch.java.lang.Integer = 숫자를 입력해주세요!!!!!
typeMismatch = 타입 오류입니다!!!!

#Bean Validation 추가
NotNull.validation.minVal = 널 안됨!!
Range={0}, {2} ~ {1} 허용
Max={0}, 최대 {1}
NotNull={0} Null 안됨!!!!

 

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Validation {

//    @NotNull(message = "값 필수 입력!")
//    @NotNull(message = "{NotNull}")
    @NotNull
    @Min(1)
    private Integer minVal;

    @Max(100)
    private Integer maxVal;

    @Range(min = 10, max = 100)
    private Integer rangeVal;

}

 

@Slf4j
@RestController
public class ValidationController {

    @GetMapping("/test")
    public String setValues(@Validated @ModelAttribute Validation validation, BindingResult bindingResult) {
        log.info("validation={}", validation);
        if (bindingResult.hasErrors()) {
            List<FieldError> fieldErrors = bindingResult.getFieldErrors();
            for (FieldError fieldError : fieldErrors) {
                log.info("errorMessage={}", fieldError.getDefaultMessage());
            }
        }
        return "OK";
    }
}

 

위와 같이 작성을 하였고 에러를 발생시켜 보면

errorMessage={}의 로그 부분에서 errors.properties에 설정한 메시지가 아니라

스프링에서 기본으로 제공하는 오류 메시지가 출력됩니다.

 

  1. 여러가지 테스트 결과

 

강의에서의 프로젝트와 다른 점이 버전 뿐인 것 같은데,

혹시 자바 혹은 스프링 부트의 버전에 따라 검증 애너테이션의 메시지가 적용되는 로직에 차이가 있나요?

그게 아니라면 어떤 이유로 이렇게 되는 건지 꼭 이유를 알고 싶습니다.

 

제가 작성한 부분 중 틀린 부분이나 추가해야 할 부분이 있다면 알려주세요..!

여러군데 검색을 해봤지만 원하는 답을 얻을 수 없어 질문 올립니다!

spring mvc

답변 2

0

김영한

안녕하세요. HyunRian님 🙂

다음을 참고해주세요.

https://www.inflearn.com/questions/263918

감사합니다.

1

HyunRian

안녕하세요 김영한 선생님!

타임리프의 에러 메시지 처리 방식(MessageSource)과

직접 컨트롤러에서 확인 또는 API 사용 시 에러 메시지 처리 방식에 차이가 있어

메시지를 확인하는 방식이 다르다고 이해했는데 맞을까요?

 

알려주신 내용대로 타임리프로 메시지를 확인해보니 제가 등록한 메시지로 출력되는 것을 확인했습니다.

컨트롤러에서 메시지를 로그로 찍어 확인해보려면

bindingResultfieldError.getDefaultMessage가 아니라

messageSource.getMessage(code, args, locale)로 값을 얻는 방법을 써야하는 것이군요.

 

답변 감사드립니다!

2

김영한

네 맞습니다. 타임리프는 내부에서 해당 로직을 호출해서 자동으로 처리해주는 것이지요 🙂

감사합니다.

0

David

안녕하세요. HyunRian님, 공식 서포터즈 David입니다.

도움을 드리고 싶지만 질문 내용만으로는 답변을 드리기 어렵습니다.

실제 동작하는 전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx

주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

 

추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명

 

링크: 공식 서포터즈

링크: 자주하는 질문

감사합니다.


0

HyunRian

안녕하세요 David님, 공유 링크 첨부합니다.

https://drive.google.com/file/d/1kWrbMjHlEoRWRNn0OM96IZTXAvuFIGni/view?usp=drive_link

 

  1. 문제 영역 실행 방법

  • 프로젝트 실행 후 postman 혹은 인터넷 창에서

    http://localhost:8080/test?minVal=&maxVal=100&rangeVal=30 로 입력(minVal 필드의 값을 null로 제공)

  • 해당 파라미터의 객체: main/java/hello/review/Validation

     

  • 실행되는 컨트롤러: main/java/hello/review/ValidationController

  • 에러 메시지 설정: main/resources/errors.properties

     

 

  1. 문제에 대한 설명

  • errors.properties에 설정해놓은 @NotNull 에러 메시지가 아니라

    스프링이 기본으로 제공하는 메시지로 출력됨을 로그로 확인할 수 있음

  • 컨트롤러 클래스의 for문으로 에러가 있다면 로그가 찍히도록 해놓은 코드가 있는데(32번줄), 여기서 제가 설정한 메시지가 아닌 스프링 기본 메시지로 출력됩니다

  • 로그 내용: errorMessage=널이어서는 안됩니다

 

추가로 더 필요한 부분이 있다면 알려주시기 바랍니다. 감사합니다!

이미지 업로드와 db 트랜잭션 묶는법

0

41

1

Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4

0

52

2

MessageSourceTest 코드

0

46

1

인터셉터 에러 설정

0

48

1

resolveArgument()메서드 질문

0

55

1

43강 검증1 에서 실패 로직 관련 질문있습니다.

0

53

2

타임리프 3.X 버전 rendering, serializer 에러 해결 방법

2

132

3

스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ

0

88

3

pdf 오타 문의

0

56

1

ItemUpdateForm 검증 관련 질문입니다.

0

47

1

22page 링크 주소 변경

0

58

2

특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문

0

52

1

섹션3번 수업에 대한 질문입니다.

0

79

2

@Autowired 보다 더 좋은 방법이 어떤 걸까요?

0

84

2

타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.

0

64

1

자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다

0

141

3

스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문

0

63

1

톰캣 에러 페이지가 안보입니다.

0

100

2

apiEceptionController에서 센드 에러 호출하면 안되는지?

0

80

1

세션 타임아웃시 쿠키 삭제 방법이 없나요?

0

118

2

ApiExceptionController 질문드립니다.

0

62

1

셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?

0

64

1

MemberRepository 필드의 fianl 선언 유무

0

84

2

혹시 index.html 에서는 fragment 사용이 안되는건가요

0

57

1