Spring MVC/MVC 프레임워크 만들기 7

[Spring MVC] 프레임워크 만들기 - 정리

정리 지금까지 v1 ~ v5로 점진적으로 프레임워크를 발전시켜 왔다. v1: 프론트 컨트롤러를 도입 기존 구조를 최대한 유지하면서 프론트 컨트롤러를 도입 v2: View 분류 단순 반복 되는 뷰 로직 분리 v3: Model 추가 서블릿 종속성 제거 뷰 이름 중복 제거 v4: 단순하고 실용적인 컨트롤러 v3와 거의 비슷 구현 입장에서 ModelView를 직접 생성해서 반환하지 않도록 편리한 인터페이스 제공 v5: 유연한 컨트롤러 어댑터 도입 어댑터를 추가해서 프레임워크를 유연하고 확장성 있게 설계 여기에 애노테이션을 사용해서 컨트롤러를 더 편리하게 발전시킬 수도 있다. 만약 애노테이션을 사용해서 컨트롤러를 편리하게 사용할 수 있게 하려면 어떻게 해야 할까? 바로 애노테이션을 지원하는 어댑터를 추가하면 된다..

[Spring MVC] 프론트 컨트롤러 - 어댑터 추가 (2)

유연한 컨트롤러 - V5 FrontControllerServletV5에 ControllerV4 기능도 추가해 보자. private void initHandlerMappingMap() { handlerMappingMap.put("/front-controller/v5/v3/members/new-form", new MemberFormControllerV3()); handlerMappingMap.put("/front-controller/v5/v3/members/save", new MemberSaveControllerV3()); handlerMappingMap.put("/front-controller/v5/v3/members", new MemberListControllerV3()); //V4 추가 handlerM..

[Spring MVC] 프론트 컨트롤러 - 어댑터 추가 (1)

유연한 컨트롤러 - V5 만약 어떤 개발자는 ControllerV3 방식으로 개발하고 싶고, 어떤 개발자는 ControllerV4 방식으로 개발하고 싶다면 어떻게 해야 할까? public interface ControllerV3 { ModelView process(Map paramMap); } public interface ControllerV4 { String process(Map paramMap, Map model); } 어댑터 패턴 지금까지 우리가 개발한 프론트 컨트롤러는 한 가지 방식의 컨트롤러 인터페이스만 사용할 수 있다. ControllerV3 , ControllerV4는 완전히 다른 인터페이스이다. 따라서 호환이 불가능하다. 마치 v3는 110v이고, v4는 220v 전기 콘센트 같은 것이다..

[Spring MVC] 프론트 컨트롤러 - 단순하고 실용적인 컨트롤러

단순하고 실용적인 컨트롤러 - V4 앞서 만든 v3 컨트롤러는 서블릿 종속성을 제거하고 뷰 경로의 중복을 제거하는 등, 잘 설계된 컨트롤러이다. 그런데 실제 컨트톨러 인터페이스를 구현하는 개발자 입장에서 보면, 항상 ModelView 객체를 생성하고 반환해야 하는 부분이 조금은 번거롭다. 좋은 프레임워크는 아키텍처도 중요하지만, 그와 더불어 실제 개발하는 개발자가 단순하고 편리하게 사용할 수 있어야 한다. 소위 실용성이 있어야 한다. 이번에는 v3를 조금 변경해서 실제 구현하는 개발자들이 매우 편리하게 개발할 수 있는 v4 버전을 개발해 보자. V4 구조 기본적인 구조는 V3와 같다. 대신에 컨트롤러가 ModelView를 반환하지 않고, ViewName 만 반환한다. ControllerV4 public ..

[Spring MVC] 프론트 컨트롤러 - Model 추가

Model 추가 - V3 서블릿 종속성 제거 컨트롤러 입장에서 HttpServletRequest, HttpServletResponse이 꼭 필요할까? @Override public MyView process(HttpServletRequest request, HttpServletResponse response) 요청 파라미터 정보는 자바의 Map으로 대신 넘기도록 하면 지금 구조에서는 컨트롤러가 서블릿 기술을 몰라도 동작할 수 있다. 그리고 request 객체를 Model로 사용하는 대신에 별도의 Model 객체를 만들어서 반환하면 된다. 우리가 구현하는 컨트롤러가 서블릿 기술을 전혀 사용하지 않도록 변경해 보자. 이렇게 하면 구현 코드도 매우 단순해지고, 테스트 코드 작성이 쉽다. 뷰 이름 중복 제거 컨..

[Spring MVC] 프론트 컨트롤러 - View 분리

View 분리 - V2 String viewPath = "/WEB-INF/views/new-form.jsp"; RequestDispatcher dispatcher = request.getRequestDispatcher(viewPath); dispatcher.forward(request, response); 앞서 프론트 컨트롤러 도입을 통해, 모든 컨트롤러의 입구를 하나로 만들어보았다. 하지만 위의 코드처럼 모든 컨트롤러에서 뷰로 이동하는 부분에 중복이 있고, 깔끔하지 않다. 이 부분도 프론트 컨트롤러를 통해 분리하여 공통 처리해 보도록 하자. V2 구조 앞의 V1 구조와 달라진 점은 MyView의 존재 여부이다. 프론트 컨트롤러를 통해 각 컨트롤러를 호출하게 되고 해당 컨트롤러는 자신의 로직을 수행한 뒤..

[Spring MVC] 프론트 컨트롤러 패턴

프론트 컨트롤러 패턴 소개 프론트 컨트롤러 도입 전 요청이 들어오는 입구가 여러 곳 프론트 컨트롤러 도입 후 FrontController 패턴 특징 프론트 컨트롤러 서블릿 하나로 클라이언트의 요청을 받음 프론트 컨트롤러가 요청에 맞는 컨트롤러를 찾아서 호출 요청이 들어오는 입구가 하나 공통 처리 가능 프론트 컨트롤러를 제외한 나머지 컨트롤러는 서블릿을 사용하지 않아도 됨 스프링 웹 MVC와 프론트 컨트롤러 스프링 웹 MVC의 핵심은 FrontController이다. 스프링 웹 MVC의 DispatcherServlet이 FrontController 패턴으로 구현되어 있다. 프론트 컨트롤러 도입 - V1 프론트 컨트롤러를 단계적으로 도입해 보자. 이번 목표는 기존 코드를 최대한 유지하면서, 프론트 컨트롤러를..