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

dnjswo410님의 프로필 이미지
dnjswo410

작성한 질문수

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

유틸리티 객체와 날짜

타임리프 에러

해결된 질문

작성

·

464

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오) 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오) 아니오
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오) 예

[질문 내용]
본 강의에 그대로 따라서 코드를 작성했는데, 에러가 발생합니다.

 

@Controller
@RequestMapping("/basic")
public class BasicController {

    @GetMapping("/text-basic")
    public String textBasic(Model model) {
        model.addAttribute("data", "hello spring!");
        return "basic/text-basic";
    }

    @GetMapping("/text-unescaped")
    public String textUnescaped(Model model) {
        model.addAttribute("data", "Hello <b>Spring!</b>");
        return "basic/text-unescaped";
    }

    @GetMapping("/variable")
    public String variable(Model model) {

        User userA = new User("userA", 10);
        User userB = new User("userB", 10);

        List<User> list = new ArrayList<>();
        list.add(userA);
        list.add(userB);

        Map<String, User> map = new HashMap<>();
        map.put("userA", userA);
        map.put("userB", userB);

        model.addAttribute("user", userA);
        model.addAttribute("users", list);
        model.addAttribute("userMap", map);

        return "basic/variable";
    }

    @GetMapping("/basic-objects")
    public String basicObjects(Model model, HttpServletRequest request,
                               HttpServletResponse response, HttpSession session) {

        session.setAttribute("sessionData", "Hello Session");
        model.addAttribute("request", request);
        model.addAttribute("response", response);
        model.addAttribute("servletContext", request.getServletContext());
        return "basic/basic-objects";
    }

    @GetMapping("/date")
    public String date(Model model) {
        model.addAttribute("localDateTime", LocalDateTime.now());
        return "basic/date";
    }

    @Component("helloBean")
    static class HelloBean {
        public String hello(String data) {
            return "Hello " + data;
        }
    }

    @Data
    static class User {
        private String username;
        private int age;

        public User(String username, int age) {
            this.username = username;
            this.age = age;
        }
    }
}
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>LocalDateTime</h1>
    <ul>
        <li>default = <span th:text="${localDateTime}"></span></li>
        <li>yyyy-MM-dd HH:mm:ss = <span th:text="${#temporals.format(localDateTime,  'yyyy-MM-dd HH:mm:ss')}"></span></li>
    </ul>
    <h1>LocalDateTime - Utils</h1>
    <ul>
        <li>${#temporals.day(localDateTime)} = <span th:text="${#temporals.day(localDateTime)}"></span></li>
        <li>${#temporals.month(localDateTime)} = <span th:text="$ {#temporals.month(localDateTime)}"></span></li>
        <li>${#temporals.monthName(localDateTime)} = <span th:text="$ {#temporals.monthName(localDateTime)}"></span></li>
        <li>${#temporals.monthNameShort(localDateTime)} = <span th:text="$ {#temporals.monthNameShort(localDateTime)}"></span></li>
        <li>${#temporals.year(localDateTime)} = <span th:text="${#temporals.year(localDateTime)}"></span></li>
        <li>${#temporals.dayOfWeek(localDateTime)} = <span th:text="$ {#temporals.dayOfWeek(localDateTime)}"></span></li>
        <li>${#temporals.dayOfWeekName(localDateTime)} = <span th:text="$ {#temporals.dayOfWeekName(localDateTime)}"></span></li>
        <li>${#temporals.dayOfWeekNameShort(localDateTime)} = <span th:text="$ {#temporals.dayOfWeekNameShort(localDateTime)}"></span></li>
        <li>${#temporals.hour(localDateTime)} = <span th:text="${#temporals.hour(localDateTime)}"></span></li>
        <li>${#temporals.minute(localDateTime)} = <span th:text="$ {#temporals.minute(localDateTime)}"></span></li>
        <li>${#temporals.second(localDateTime)} = <span th:text="$ {#temporals.second(localDateTime)}"></span></li>
        <li>${#temporals.nanosecond(localDateTime)} = <span th:text="$ {#temporals.nanosecond(localDateTime)}"></span></li>
    </ul>
</body>
</html>

다른 질문을 찾아보니까 ul 태그 밑에 li 태그가 한줄로 넣어야 된다고 해서 그렇게 했는데도 오류가 발생합니다. 정확하게는 <h1>LocalDateTime - Utils</h1> 아래의 ul 태그 밑에서 부터 오류가 발생합니다.

 

오류 메시지는 다음과 같습니다.

org.thymeleaf.exceptions.TemplateProcessingException: Could not parse as expression: "$ {#temporals.month(localDateTime)}" (template: "basic/date" - line 16, col 56)

도움 주시면 감사하겠습니다 ㅠ

 

답변 2

0

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

AI 답변을 참고해주시고, 추가로 궁금한 사항은 제 댓글의 답글 혹은 질문을 새로 남겨주세요

감사합니다.

0

안녕하세요, 인프런 AI 인턴입니다. dnjswo410님

질문자님께서 겪고 계신 문제는 Thymeleaf 템플릿에서 발생한 Could not parse as expression 오류와 관련이 있습니다. 이 오류는 Thymeleaf 표현식이 적절하게 해석되지 않았을 때 발생합니다.

제공된 코드 예시에 따르면, 표현식에서 사용된 $ 기호와 중괄호 {} 사이에 공백이 존재합니다. Thymeleaf에서 변수를 참조할 때는 ${variable} 형식으로 공백 없이 작성해야 합니다. 오류 메시지에서 볼 수 있듯이, $ {#temporals.month(localDateTime)} 이부분에서 문제가 발생한 것으로 추정됩니다.

이를 해결하기 위해서는 다음과 같이 공백을 제거하여 올바른 형식으로 수정하셔야 합니다.

<li>${#temporals.month(localDateTime)} = <span th:text="${#temporals.month(localDateTime)}"></span></li>

위와 같이 ${#temporals.month(localDateTime)} 부분의 공백을 제거해주시면 오류가 해결될 것입니다.

이와 유사한 문제를 겪고 계신 다른 수강생의 경우를 살펴보실 수 있도록 몇 가지 링크를 공유해드립니다. 여기서 제공된 정보들이 질문자님의 문제를 해결하는 데 도움이 될 수 있습니다.

  • Could not parse as expression 에러 - 유사한 문제가 보고되며, 해결 방안을 제공하는 답변을 참조하실 수 있습니다.

  • 기본객체들 404 - 이는 URL 경로 문제와 관련되어 있지만, 비슷한 문맥에서 @GetMapping 관련 문제를 다루고 있습니다.

  • 복붙 에러 - 복사 붙여넣기 과정에서 발생하는 유사한 오류에 대한 답변을 보실 수 있습니다.

  • 타임리프 syntax 에러 - 타임리프에서 발생하는 구문 오류에 대한 질문 및 답변을 보실 수 있습니다.

코드 수정 후에도 문제가 해결되지 않거나, 현재 상황에 맞는 해결책이 필요하시면 추가적인 질문을 올려주시면 강사님이나 다른 수강생이 도움을 줄 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

dnjswo410님의 프로필 이미지
dnjswo410

작성한 질문수

질문하기