인프런 커뮤니티 질문&답변

코딩먹는하마님의 프로필 이미지
코딩먹는하마

작성한 질문수

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

스프링이 제공하는 기본 포맷터

formatter에 pattern이 일어나는 시점

작성

·

501

·

수정됨

0

 @GetMapping("/formatter/edit")
    public String formatterForm(Model model){
        Form form = new Form();
        form.setNumber(10000);
        form.setLocalDateTime(LocalDateTime.now());
        log.info("form={}",form);
        model.addAttribute("form",form);
        return "formatter-form";
    }
    @PostMapping("/formatter/edit")
    public String formatterEdit(@ModelAttribute Form form){
        log.info("post form={}",form);
        return "formatter-view";
    }

로그를 통해 form, post form을 출력해보았습니다.

저는 처음 form은 그냥 입력한 값이 나오고 그다음 post form은 ModelAttribute에 들어갈 때

public String formatterEdit(@ModelAttribute Form form){

포멧터가 form의 타입을 변경하고 입력한다고 예상했습니다.

하지만 로그를 보니

 form=FormatterController.Form(number=10000, localDateTime=2023-04-23T12:39:53.251212)
 post form=FormatterController.Form(number=10000, localDateTime=2023-04-23T12:39:53)

값은 값이 나오는 것을 확인했습니다.

 

제가 생각했을 때는 Argument Resolver 안에 ConversionService 안에 Formatter 가 controller를 호출하기 전 @ModelAttribute에 입력할 때 실행되지만

@Data
    static class Form{
        @NumberFormat(pattern = "###,###")
        private Integer number;

        @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
        private LocalDateTime localDateTime;
    }

에서 @NumberFormat(pattern = "###,###") 패턴이 적용 되는 시점은 html에서

"${{form.number}}"

중괄호2개가 있을 때다. 그래서 로그는 값은 같은 값이 출력이 되지만 html에서는 다른 값이 출력된다. 라고 이해를 했는 데 맞게 생각한 것인지 궁금합니다.

 

답변주시면 정말 감사하겠습니다.

답변 1

0

안녕하세요. 코딩먹는하마님, 공식 서포터즈 David입니다.

thymeleaf에서 html파일을 렌더링할 때 formatter가 호출되어 정해진 패턴을 따라 데이터를 문자열로 출력하게 됩니다.

아래 라인에 브레이크 포인트를 걸고 디버깅 해보시면 이 과정을 자세히 확인하실 수 있습니다.

https://github.com/spring-projects/spring-framework/blob/main/spring-context/src/main/java/org/springframework/format/number/AbstractNumberFormatter.java#L51

감사합니다.

코딩먹는하마님의 프로필 이미지
코딩먹는하마

작성한 질문수

질문하기