작성
·
152
·
수정됨
0
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예
[질문 내용]
섹션 2에서, 멀티 체크 박스를 만들 때 다음과 같은 메소드를 구현했습니다.
@Slf4j
@Controller
@RequestMapping("/form/items")
@RequiredArgsConstructor
public class FormItemController {
private final ItemRepository itemRepository;
@ModelAttribute("regions")
public Map<String, String> regions() {
Map<String, String> regions = new LinkedHashMap<>();
regions.put("SEOUL", "서울");
regions.put("BUSAN", "부산");
regions.put("JEJU", "제주");
return regions;
}
//...
}
위 메소드는 컨트롤러마다 호출되어 모델에 Attribute를 자동으로 추가해주고 있습니다.
근데, 이 코드를 구현하면서 다음과 같은 의문이 들었습니다.
regions map에 들어가는 키-값 벨류는 비즈니스 로직에 해당하지 않나?
비즈니스 로직이면 컨트롤러보단 서비스에 구현되어야 하는 내용이 아닌가?
제가 MVC와 비즈니스 로직에 대한 개념이 아직 부족한건지,
혹은 예제니까 간단하게 컨트롤러에 구현하신건가요?
답변 1
0
안녕하세요, 인프런 AI 인턴이에요.
@ModelAttribute 어노테이션은 스프링 프레임워크에서 모델에 데이터를 자동으로 추가해주는 기능을 제공하는 어노테이션입니다. 이어서 질문하신 부분에 대한 답을 드리겠습니다.
regions map에 들어가는 키-값 벨류는 비즈니스 로직에 해당하지 않나?
- 맞습니다. regions map은 컨트롤러의 모델에 추가되는 데이터로, 비즈니스 로직에 직접적으로 연관되는 내용은 아닙니다. 일반적으로 비즈니스 로직은 서비스 계층에 구현하고, 컨트롤러는 클라이언트와의 상호작용을 담당합니다. regions map은 화면에 표시될 내용으로, 컨트롤러에서 모델에 추가해주는 것이 일반적입니다.
비즈니스 로직이면 컨트롤러보단 서비스에 구현되어야 하는 내용이 아닌가요?
- 맞습니다. 일반적으로 비즈니스 로직은 서비스 계층에 구현됩니다. 그러나 예제에서 regions map은 단순히 화면에 표시될 데이터이고, 복잡한 비즈니스 로직이 아니기 때문에 컨트롤러에서 직접 구현한 것으로 보입니다. 이는 예제에서의 간소화된 구현 방식이며, 실제 프로젝트에서는 비즈니스 로직을 서비스 계층에 구현하고, 컨트롤러에서 해당 서비스를 호출하여 데이터를 모델에 추가하는 것이 일반적입니다.
MVC와 비즈니스 로직에 대한 개념이 부족한건지, 예제니까 간단하게 컨트롤러에 구현하신건지 여쭤보고 싶습니다.
- MVC 패턴은 어플리케이션의 코드를 모듈화하여 유지보수와 확장성을 높이기 위한 디자인 패턴입니다. Model, View, Controller로 구성되며, 비즈니스 로직은 주로 Model 계층에 구현됩니다. 하지만 예제의 경우 regions map은 단순한 데이터이므로, 예제의 편의를 위해서 컨트롤러에서 구현된 것으로 보입니다. 따라서, 예제를 보다 효율적으로 이해하고 싶다면 MVC 패턴과 비즈니스 로직에 대한 개념을 좀 더 학습하시는 것을 권장드립니다.
더 궁금한 점이 있으시면 언제든지 물어보세요!