MVC 디자인 패턴이란?
- MVC란 Model-View-Controller의 약자로, 소프트웨어 디자인 패턴 중 하나이다.
- 소프트웨어를 구성하는 요소들을 Model, View, Controller로 구분하여 각각의 역할을 분리하여, 코드의 재사용성과 유지보수성을 높이고, 개발자들 간의 협업을 용이하게 한다.

Model
- 데이터와 비즈니스 로직 담당
- 데이터베이스와 연동하여 데이터를 저장하고 불러오는 등의 작업 수행
View
- 사용자 인터페이스 담당
- 사용자가 보는 화면과 버튼, 폼 등을 디자인하고 구현
Controller
- Model과 View 사이의 상호작용을 조정, 제어
- 사용자의 입력을 받아 Model에 전달하고, Model의 결과를 바탕으로 View를 업데이트
Spring MVC란?
- DispatcherServlet이 중앙에서 HTTP 요청을 처리해주는데 이는 Front Controller 패턴으로 설계되어있다.
Servlet이란?
- Servlet(서블릿)은 자바를 사용하여 웹 페이지를 동적으로 생성하는 서버 측 프로그램 혹은 그 사양을 말한다.
- [사용자가 (HTTP) API 요청했을 때 서버의 서블릿 동작 과정]

- 사용자가 Client(브라우저)를 통해 서버에 HTTP Request 즉, API 요청
- 요청을 받은 Servlet 컨테이너는 HttpServletRequest, HttpServletResponse 객체를 생성
- 약속된 HTTP의 규격을 맞추면서 쉽게 HTTP에 담긴 데이터를 사용하기 위한 객체
- 설정된 정보를 통해 어떠한 Servlet에 대한 요청인지 찾기
- 해당 Servlet에서 service 메서드를 호출한 뒤 브라우저의 요청 Method에 따라 doGet 혹은 doPost 등의 메서드를 호출
- 호출한 메서드들의 결과를 그대로 반환하거나 동적 페이지를 생성한 뒤 HttpServletResponse 객체에 응답을 담아 Client(브라우저)에 반환
- 응답이 완료되면 생성한 HttpServletRequest, HttpServletResponse 객체 소멸
Front Controller
- 모든 API 요청을 서블릿의 동작 방식에 맞춰 코드를 구현한다면 무수히 많은 Servlet 클래스를 구현해야한다.
- 따라서 Spring은 DispatcherServlet을 사용하여 Front Controller 패턴 방식으로 API 요청을 효율적으로 처리하고 있다.
- [Front Controller 패턴의 동작 과정]

- Client(브라우저)에서 HTTP 요청이 들어오면 DispatcherServlet 객체가 요청을 분석
- DispatcherServlet 객체는 분석한 데이터를 토대로 Handler mapping을 통해 Controller를 찾아 요청을 전달
- Handler mapping 에는 API path 와 Controller 메서드가 매칭되어 있다.
- [example]
- POST /user/signup → UserController 의 registerUser() 함수
- GET /user/signup → UserController 의 signup() 함수
- GET /user/login → UserController 의 login() 함수
- Controller → DispathcerServlet
해당 Controller는 요청에 대한 처리를 완료 후 처리에 대한 결과 즉, 데이터('Model')와 'View' 정보를 전달
- DispatcherServlet → Client
ViewResolver 통해 View에 Model을 적용하여 View를 Client에게 응답으로 전달
마무리
그냥 따라서 치던 코드들이 어떻게 작동하는지에 대해서 개념이 부족한 것 같아 정리해보았다. 새로운 기술을 배우는 것도 중요하지만, 그러기 위해서는 작동 원리 기본이 튼튼해야 한다는 생각이 들었다.
Dip을 극복한다는 것
참고자료
- 항해99 Spring Master 수업자료 Spring MVC란 ?