typeMismatch + @ 질문있습니다
1888
작성한 질문수 2
안녕하세요. 영한님
다름이 아니라 테스트해보다가 궁금한 점이 있어 문의 드립니다.
강의 예시와 같이 typeMismatch를 발생 시켰을 때 로그 상으로 default message에 스프링이 제공하는 기본 메시지가 나오는 걸 확인 했습니다.
여기서 궁금한 점이 있습니다.
1. typeMismatch가 발생하는 경우엔 error.properites에서 메시지를 찾는 시점이 바인딩이 정상적으로 동작하여 Validator가 적용되는 경우와 다른 걸까요?
2. 콘솔 로그엔 스프링 제공 기본 메시지가 찍히지만 클라이언트 단에는 의도한 메시지가 노출되고 있는데요. 서버단에서 typeMismatch에 대한 메시지 내용을 찾기 위해선 추가적인 로직이 필요한 걸까요? (e.g. typeMismatch인 경우 error.properites의 값을 가져온다 등..)
3.bindingResult.hasErrors() 로직을 매번 확인하기 번거로워 @ExceptionHandler(BindException.class)를 이용하여 공통 처리해봤는데요, 괜찮은 방법일까요? (-> 검증 에러 발생 시 클라이언트단 input태그 옆 같은 특정 위치에 노출하는 게 아니라 비동기 통신 시 bindingResult의 첫번째 에러 내용을 안내하는 식으로 사용한다는 가정하에 작성했습니다.)
의미가 잘 전달됐는지 모르겠습니다.. 언제나 좋은 강의 감사드립니다 :)
답변 3
2
안녕하세요. Seungsik Nam님
자세히 적어주신 덕분에 질문을 이해했습니다.
서버에서는 오류 코드와 디폴트 메시지를 보내고,
실제 오류 메시지를 찾아서 처리해주는 부분은 타임리프에서 해주는 것입니다.
타임리프가 오류 코드를 기반으로 메시지소스를 찾아서 처리해주는 것이지요.
서버에서 이 오류 메시지를 처리하려면 다음을 읽어보시면 도움이 되실거에요.
https://www.inflearn.com/questions/263918
감사합니다.
1
안녕하세요. Seungsik Nam님
1, 2번 질문 관련해서 좀 더 자세히 설명해주시겠어요? 스크린샷과 코드로 관련된 부분을 최대한 많이 남기면서 설명해주시면 좋겠습니다. 추가로 실행하고 재연하는 방법도 함께 남겨주세요.
3번 질문은 크게 문제가 없을 것 같아요.
감사합니다.
0
주말임에도 답변 주셔서 감사드립니다..!
다음과 같이 진행하였습니다.
0. errors.properties 일부
typeMismatch=타입 오류입니다.
NotBlank={0} 공백X
Range={0}, {2} ~ {1} 허용
Max={0}, 최대 {1}
1. http://localhost:8080/validation/v4/items/add 접근 후 가격에 'aa' 라는 문자열 입력 시 결과 화면

2. 해당 요청을 처리하는 Controller
@PostMapping("/add")
public String addItemV2(@Validated @ModelAttribute("item") ItemSaveForm form, BindingResult bindingResult, RedirectAttributes redirectAttributes, Model model) {
if (form.getPrice() != null && form.getQuantity() != null) {
int resultPrice = form.getPrice() * form.getQuantity();
if (resultPrice < 10000) {
bindingResult.reject("totalPriceMin", new Object[]{10000, resultPrice}, null);
}
}
if (bindingResult.hasErrors()) {
log.info("errors : {}", bindingResult);
return "validation/v4/addForm";
}
Item item = new Item();
item.setItemName(form.getItemName());
item.setPrice(form.getPrice());
item.setQuantity(form.getQuantity());
Item savedItem = itemRepository.save(item);
redirectAttributes.addAttribute("itemId", savedItem.getId());
redirectAttributes.addAttribute("status", true);
return "redirect:/validation/v4/items/{itemId}";
}
3. log.info("errors : {}", bindingResult); 콘솔 로그 내용
2022-02-05 20:08:45.875 INFO 46727 --- [nio-8080-exec-7] h.i.w.v.ValidationItemControllerV4 : errors : org.springframework.validation.BeanPropertyBindingResult: 3 errors
Field error in object 'item' on field 'price': rejected value [aa]; codes [typeMismatch.item.price,typeMismatch.price,typeMismatch.java.lang.Integer,typeMismatch]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [item.price,price]; arguments []; default message [price]]; default message [Failed to convert property value of type 'java.lang.String' to required type 'java.lang.Integer' for property 'price'; nested exception is java.lang.NumberFormatException: For input string: "aa"]
Field error in object 'item' on field 'itemName': rejected value []; codes [NotBlank.item.itemName,NotBlank.itemName,NotBlank.java.lang.String,NotBlank]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [item.itemName,itemName]; arguments []; default message [itemName]]; default message [공백일 수 없습니다]
Field error in object 'item' on field 'quantity': rejected value [null]; codes [NotNull.item.quantity,NotNull.quantity,NotNull.java.lang.Integer,NotNull]; arguments [org.springframework.context.support.DefaultMessageSourceResolvable: codes [item.quantity,quantity]; arguments []; default message [quantity]]; default message [널이어서는 안됩니다]
4. log.info("errors : {}", bindingResult); Break point 설정 후 확인

위 이미지에서 보신 것 처럼 typeMismatch 발생 시 errors.properties에 작성된 내용과 달리 defaultMessage는 스프링이 제공하는 기본 에러 메시지가 담겨있는 것을 확인할 수 있습니다. 물론 클라이언트단에선 의도대로 properties에 작성한 메시지가 정상 노출됩니다.
이런 현상 때문에 바인딩 성공 여부에 따라 properties에 작성된 메시지가 defaultMessage에 적용되는 시점이 다른 것인지 (1번질문) 문의드렸으며 typeMismatch 발생 시 properties에 작성된 메시지를 서버단에서 이용하려면 어떤 처리가 필요한지 (2번질문) 문의드렸습니다.
감사합니다.
0
안녕하세요, 영한님
typeMismatch 발생 시 서버단에서 errors.properties 에 작성된 내용을 defaultMessage에 적용되게 하고자 했지만 생각처럼 잘 되지않아 MessageSource를 이용하는걸로 타협했습니다.. (2번 질문과 관련된 내용입니다.)
@Slf4j
@Controller
@RequestMapping("/validation/v4/items")
@RequiredArgsConstructor
public class ValidationItemControllerV4 {
private final MessageSource messageSource;
....
@PostMapping("/add")
public String addItemV2(@Validated @ModelAttribute("item") ItemSaveForm form, BindingResult bindingResult, RedirectAttributes redirectAttributes, Model model) {
if (bindingResult.hasErrors()) {
log.info("errors : {}", bindingResult);
for (FieldError fieldError : bindingResult.getFieldErrors()) {
if (fieldError.getCode().contains("typeMismatch")) {
String typeMismatch = messageSource.getMessage("typeMismatch", null, LocaleContextHolder.getLocale());
log.info("typeMismatch Properties Msg : {}", typeMismatch);
log.info("typeMismatch Default Msg : {}", fieldError.getDefaultMessage());
}
}
return "validation/v4/addForm";
}
}
해당 소스는 테스트로 작성한 부분이며 실제로는 @ExceptionHandler에 다른 형태로 사용하고 있습니다.
MessageSource이용하는 방법 외에 더 좋은 방안이 있다면 조언 부탁드리겠습니다.
감사합니다 :)
이미지 업로드와 db 트랜잭션 묶는법
0
40
1
Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4
0
45
2
MessageSourceTest 코드
0
46
1
인터셉터 에러 설정
0
47
1
resolveArgument()메서드 질문
0
54
1
43강 검증1 에서 실패 로직 관련 질문있습니다.
0
52
2
타임리프 3.X 버전 rendering, serializer 에러 해결 방법
2
130
3
스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ
0
86
3
pdf 오타 문의
0
54
1
ItemUpdateForm 검증 관련 질문입니다.
0
46
1
22page 링크 주소 변경
0
55
2
특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문
0
52
1
섹션3번 수업에 대한 질문입니다.
0
78
2
@Autowired 보다 더 좋은 방법이 어떤 걸까요?
0
84
2
타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.
0
63
1
자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다
0
140
3
스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문
0
62
1
톰캣 에러 페이지가 안보입니다.
0
98
2
apiEceptionController에서 센드 에러 호출하면 안되는지?
0
80
1
세션 타임아웃시 쿠키 삭제 방법이 없나요?
0
116
2
ApiExceptionController 질문드립니다.
0
62
1
셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?
0
64
1
MemberRepository 필드의 fianl 선언 유무
0
83
2
혹시 index.html 에서는 fragment 사용이 안되는건가요
0
57
1





