Summary

다음과 같은 기능을 하는 간단한 회원 관리 웹 애플리케이션을 만들어보았다.

  1. 회원 등록(new-form)

  2. 회원 등록 후 저장된 회원 정보 렌더링(save)

  3. 회원 리스트 조회(list)

  • servlet으로 구현 : 비즈니스 로직 구현은 쉬웠지만, html을 작성할 때 자바로 구현하는 데에 어려움이 있었다.

  • JSP로 구현 : 반대로 html 안에 자바 코드가 있다

결론적으로 servlet으로 구현할 때, JSP로 구현할 때 모두 비즈니스 로직과 뷰가 혼합되어 있어서 어느 한쪽을 수정해야할 때 둘다 수정해야할 수도 있고, 유지보수가 어렵다는 단점이 있다.

MVC 패턴 등장! 비즈니스로직과 뷰를 분리하고 사이에 Model을 매개체로 데이터를 주고 받는다! 여기서 매개체는 HttpServletRequest 객체를 사용하여 request.getAttribute(), request.getAttribute() 를 사용하면 데이터를 보관하고, 조회할 수 있다.

단순 MVC 패턴의 한계점 중복이 많이 존재한다. 공통 기능을 메서드로 뽑으면 될 것 같지만, 결과적으로 해당 메서드를 항상 호출해야 하고, 실수로 호출하지 않으면 문제가 될 것이다. 그리고 호출하는 것 자체도 중복이다.

프론트 컨트롤러(Front Controller) 패턴을 도입해서 컨트롤러 호출 전에 먼저 공통 기능을 처리하도록 한다!

우리가 흔히 말하는 스프링 MVC의 핵심도 바로 이 프론트 컨트롤러에 있다.

Last updated