개발/servlet

MVC 패턴

함수형 인간 2025. 3. 5. 05:39
MVC (Model-View-Controller) 패턴

MVC 패턴은 사용자 인터페이스(UI)를 가진 애플리케이션을 개발할 때 널리 사용되는 디자인 패턴이다. 애플리케이션의 구성 요소를 Model, View, Controller 세 가지 역할로 분리하여 개발하는 방식으로, 코드의 재사용성, 유지보수성, 확장성을 높이고, 개발 효율성을 향상시킨다.

1. MVC 패턴의 구성 요소 및 역할

  • Model (모델):
    • 역할: 애플리케이션의 데이터와 비즈니스 로직(데이터 처리, 가공, 유효성 검사 등)을 담당.
    • 특징:
      • 데이터베이스와 상호작용하여 데이터를 가져오거나 저장합니다. (DAO - Data Access Object)
      • 데이터의 상태 변화를 처리하고, 필요한 경우 View와 Controller에 알림.
      • View나 Controller에 대한 어떠한 정보도 가지지 않는다. (독립적)
    • 구성 요소:
      • DTO (Data Transfer Object) / VO (Value Object): 데이터를 표현하는 객체 (예: User, Product, Order)
      • DAO (Data Access Object): 데이터베이스 연동을 담당하는 객체
      • Service (서비스): 비즈니스 로직을 처리하는 객체 (예: 사용자 인증, 주문 처리, 상품 검색)
  • View (뷰):
    • 역할: 사용자에게 데이터를 시각적으로 표현(UI)하는 역할을 담당. (화면 출력)
    • 특징:
      • Model로부터 데이터를 받아와 화면에 표시.
      • 사용자와 상호작용하여 입력을 받기도 하지만, 입력 데이터의 처리나 유효성 검사는 View의 역할이 아님.
      • Controller에 대한 어떠한 정보도 가지지 않는다. (독립적)
      • 최대한 표현 로직만 포함 (최소한의 조건문, 반복문)
    • 구성 요소:
      • HTML, CSS, JavaScript: 웹 페이지의 구조, 스타일, 동작을 정의
      • JSP (JavaServer Pages): HTML 내에 Java 코드를 삽입하여 동적인 웹 페이지를 생성
      • 템플릿 엔진 (Thymeleaf, Freemarker 등): 템플릿 파일과 데이터를 결합하여 HTML을 생성
  • Controller (컨트롤러):
    • 역할: 사용자의 요청을 받아 처리하고, Model과 View 사이의 흐름을 제어하는 중개자 역할을 한다.
    • 특징:
      • 클라이언트(웹 브라우저)로부터 요청을 받는다.
      • 요청에 따라 적절한 Model을 호출하여 비즈니스 로직을 처리한다.
      • Model의 처리 결과를 View에 전달하여 화면을 생성하도록 한다.
      • 필요한 경우, 다른 Controller로 요청을 전달(forward)하거나, 클라이언트를 다른 URL로 리디렉션(redirect)한다.
    • 구성 요소:
      • Servlet: 클라이언트의 요청을 처리하는 Java 클래스
      • Spring MVC의 @Controller: Spring 프레임워크에서 컨트롤러 역할을 하는 클래스

2. MVC 패턴의 동작 흐름 (예시: 사용자 목록 조회)

  1. 사용자 요청: 사용자가 웹 브라우저에서 사용자 목록 페이지를 요청. (/users URL로 GET 요청)
  2. Controller:
    • 웹 브라우저로부터 요청을 받는다. (/users URL에 매핑된 Controller)
    • 요청을 분석하여 어떤 작업을 수행해야 하는지 결정. (사용자 목록 조회)
    • Model(UserService)에게 사용자 목록 데이터를 가져오도록 요청.
  3. Model:
    • UserService는 UserDAO를 통해 데이터베이스에서 사용자 목록 데이터를 가져온다.
    • 가져온 데이터를 List<User> (DTO) 형태로 Controller에 반환.
  4. Controller:
    • Model로부터 받은 List<User> 데이터를 View에 전달. (request attribute에 저장)
    • 사용자 목록을 표시할 View(JSP)를 선택하고, forward 한다.
  5. View:
    • Controller로부터 받은 List<User> 데이터를 사용하여 HTML 페이지를 생성. (JSP의 JSTL, EL 등을 사용하여 데이터 출력)
    • 생성된 HTML 페이지를 클라이언트(웹 브라우저)에 응답으로 전송.
  6. 사용자: 웹 브라우저에 사용자 목록 페이지가 표시된다.