[SpringBoot] Spring MVC

정재현·2024년 1월 22일
0

Spring Boot

목록 보기
12/19
post-thumbnail

MVC 디자인 패턴

  • MVC (Model-View-Controller)란 소프트웨어 디자인 패턴 중 하나
    • MVC 패턴은 소프트웨어를 구성하는 요소들을 Model, View, Controller로 구분하여 각각의 역할을 분리한다
    • MVC 패턴은 소프트웨어를 구성하는 요소들을 분리함으로써 코드의 재사용성과 유지보수성을 높이고, 개발자들 간의 협업을 용이하게 한다.
      → 따라서 소프트웨어를 개발할 때, MVC 패턴을 적용하여 구조를 잘 설계하는 것이 중요하다.

Model

  • 데이터와 비즈니스 로직을 담당
  • 데이터베이스와 연동하여 데이터를 저장하고 불러오는 등의 작업을 수행

View

  • 사용자 인터페이스를 담당
  • 사용자가 보는 화면과 버튼, 폼 등을 디자인하고 구현

Controller

  • Model과 View 사이의 상호작용을 조정하고 제어
  • 사용자의 입력을 받아 Model에 전달하고, Model의 결과를 바탕으로 View를 업데이트한다.

Spring MVC

Spring Web MVCServlet API를 기반으로 구축된 독창적인 웹 프레임워크로, 처음부터 Spring Framework에 포함되어 왔으며, 정식 명칭인 "Spring Web MVC"는 소스 모듈(spring-webmvc)의 이름에서 따왔으나, "Spring MVC"로 더 일반적으로 알려져 있다.

  • Spring MVC는 중앙에 있는 DispatcherServlet이 요청을 처리하기 위한 공유 알고리즘을 제공하는 Front Controller 패턴을 중심으로 설계되어 있으며 이 모델은 유연하고 다양한 워크 플로우를 지원한다.

Servlet 이란

Servlet (서블릿)은 자바를 사용하여 웹 페이지를 동적으로 생성하는 서버 측 프로그램 혹은 그 사양을 말한다.

사용자가 (HTTP) API 요청을 했을 때 서버의 서블릿이 동작하는 과정(Front Controller 패턴 없이 동작 과정)


1. 사용자가 Client(브라우저)를 통해 서버에 HTTP Request 즉, API 요청
2. 요청을 받은 Servlet 컨테이너는 HttpServletRequest, HttpServletResponse 객체를 생성

→ 약속된 HTTP의 규격을 맞추면서 쉽게 HTTP에 담긴 데이터를 사용하기 위한 객체
→ 개발을 할 때 매번 HTTP의 구조를 분석해서 데이터를 가져오는 행위는 비효율적이기 때문에 Servlet이 대신해서 HTTP안에 들어있는 우리가 사용할 데이터 정보들을 HttpServletRequest객체에 넣어준다.
→ 동시에 Client측의 요청에 대한 응답을 위해 HttpServeltResponse도 생성해준다.

  1. 설정된 정보를 통해 어떠한 Servlet에 대한 요청인지 찾는다.
  • 즉, API에 대한 요청을 확인해서 어떤 Servlet과 매칭이 되는지 분석
  1. 해당 Servlet에서 service 메서드를 호출한 뒤 브라우저의 요청 Method에 따라 doGet 혹은 doPost 등의 메서드를 호출
  2. 호출한 메서드들의 결과를 그대로 반환하거나 동적 페이지를 생성한 뒤 HttpServletResponse 객체에 응답을 담아 Client(브라우저)에 반환
  3. 응답이 완료되면 생성한 HttpServletRequest, HttpServletResponse 객체를 소멸

DispatcherServlet 이란

중앙에서 HTTP 프로토콜로 들어오는 모든 요청을 먼저 받아서 적합한 컨트롤러에게 위임해주는 역할 수행

  • Front Controller 패턴으로 설계되어 있다.
    → 쉽게 표현해보자면 ‘Spring에서 MVC 디자인 패턴을 적용하여 DispatcherServlet이 HTTP 요청을 효율적으로 처리하고 있다’ 라고 이해
  • 참고 : Spring 공식 문서
  • 참고한 블로그

Front Controller

모든 API 요청을 앞서 살펴본 서블릿의 동작 방식에 맞춰 코드를 구현한다면 무수히 많은 Servlet 클래스를 구현해야한다 따라서 Spring은 DispatcherServlet을 사용하여 Front Controller 패턴 방식으로 API 요청을 효율적으로 처리하고 있다.

Front Controller 패턴의 동작 과정


1. Client → DispatcherServlet
: Client(브라우저)에서 HTTP 요청이 들어오면 DispatcherServlet 객체가 요청을 분석
2. DispatcherServlet → Hander mapping && DispatcherServlet → Controller
:
DispatcherServlet는 분석한 데이터를 토대로 Handler mapping을 통해 Controller를 찾아 요청을 전달
Handler mapping 에는 API path 와 Controller 메서드가 매칭되어 있다.**

예시)

GET /api/hello → HelloController 의 hello() 함수
GET /user/login → UserController 의 login() 함수
GET /user/signup → UserController 의 signup() 함수
POST /user/signup → UserController 의 registerUser() 함수

// GetMapping이라는 메서드를 사용해서 
// 넘어온 URL경로로 Get방식으로 요청이 넘어왔을 때
// hello메서드를 호출한다 라고 자바의 애너테이션을 사용해서 정보를 전달
// 전달받는 데이터를 Handler mapping이 정보와 메서드를 매칭시킴
// 매칭된 정보를 DispatcherServlet이 확인해서 해당하는 Controller에 요청

@RestController
public class HelloController {
    @GetMapping("/api/hello")
    public String hello() {
        return "Hello World!";
    }
}
  • API path 즉, URL을 Controller에 작성하는 방법은 @Controller 애너테이션이 달려있는 클래스를 생성한 뒤 @GetMapping 처럼 요청한 HTTP Method 와 일치하는 애너테이션을 추가한 메서드를 구현
    • URL은 @GetMapping("/api/hello") 이처럼 해당 애너테이션의 속성값으로 전달해주면 된다.
    • 해당 메서드명은 URL을 매핑하는데 영향을 미치지 않음으로 자유롭게 정해도 상관 없다.
  • 이제는 직접 Servlet을 구현하지 않아도 DispatcherServlet에 의해 간편하게 HTTP 요청을 처리할 수 있게 되었다.
  1. Controller → DispathcerServlet
    : 해당 Controller는 요청에 대한 처리를 완료 후 처리에 대한 결과 데이터를 Model에 담고, View에 대한 정보와 함께 전달

  2. DispatcherServlet → Client
    : ViewResolver 통해 View에 Model을 적용하여 View를 Client에게 응답으로 전달


profile
공부 기록 보관소

0개의 댓글