해결된 질문
작성
·
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
안녕하세요, 인프런 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 에러 - 타임리프에서 발생하는 구문 오류에 대한 질문 및 답변을 보실 수 있습니다.
코드 수정 후에도 문제가 해결되지 않거나, 현재 상황에 맞는 해결책이 필요하시면 추가적인 질문을 올려주시면 강사님이나 다른 수강생이 도움을 줄 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.