실무에서는 로그 관리에 있어 SLF4J 인터페이스를 사용하고, 그 구현체로 Logback 라이브러리를 선택한다. ** 콘솔 뿐만 아니라 별도의 위치에 로그를 남길 수도 있으며, 네트워크로 로그를 전송할 수도 있다. # @RestController 어노테이션 @Controller 는 반환 값이 String 이면 뷰 이름으로 인식된다. 그래서 뷰를 찾고 뷰가 랜더링 된다. @RestController 는 반환 값으로 뷰를 찾는 것이 아니라, HTTP 메시지 바디에 바로 입력하여 문자열을 반환하면 그대로 String이 반환된다. # slf4j 인터페이스 Logger 자료형과 LoggerFactory를 할 때 slf4j 인터페이스를 선택한다. 시간, 로그 레벨, 프로세스 ID, 쓰레드 명, 클래스명, 로그 메시..
🌱 Spring/MVC ①
지금까지 ModelAndView를 생성하고 반환해줬지만, 실무에서는 다음과 같이 실용적으로 코드를 구성한다. 이전 실습에서 V3에서 V4로 넘어가면서 ModelView가 아닌 View를 가리키는 String만 반환하도록 개선한 것과 유사하다. - @RequestMapping시 실행되는 메서드의 반환형을 ModelAndView → String으로 변환한다. - 매우 유연하게 구현된 Spring의 @RequestMapping의 메서드에서는 Model을 메서드의 인자로 바로 받아올 수 있는데, 각 메서드별로 Member 추가 및 조회한 다음 model.addAttribute 메서드를 통해 처리를 수행한다. - 또한, @RequestParam을 통해 HttpServletRequest의 parameter도 바로 ..
@RequestMapping을 사용하면 RequestMappingHandlerMapping, RequestMappingHandlerAdapter를 사용한다는 의미이다. # @Controller - 스프링이 자동으로 스프링 빈으로 등록한다. @Controller은 @Component를 상속 받기 때문에 마찬가지로 컴포넌트 스캔의 대상이 된다. - 스프링 MVC에서 어노테이션 기반 컨트롤러로 인식한다. # @RequestMapping - 요청 정보를 매핑한다. 해당 URL이 호출되면 이 메서드가 호출된다. - 어노테이션을 기반으로 동작하므로, 메서드 이름(process)는 임의로 지어도 된다. # ModelAndView - 모델과 뷰 정보를 담아서 반환하면 된다. RequestMappingHandlerMap..
지금까지는 controllerMap에 특정 인터페이스를 지정하고 매핑하였기 때문에, 다른 인터페이스를 준수하는 컨트롤러는 매핑할 수 없었다. @WebServlet(name = "frontControllerServletV4", urlPatterns = "/front-controller/v4/*") public class FrontControllerServletV4 extends HttpServlet { private Map controllerMap = new HashMap(); public FrontControllerServletV4() { controllerMap.put("/front-controller/v4/members/new-form", new MemberFormControllerV4()); con..
기능 개선 매번 ModelView 객체를 생성하지 않고, 컨트롤러가 ModelView를 반환하지 않고 ViewName만 반환한다. 인터페이스에는 ModelView가 없으며, model 객체를 파라미터로 전달하기 때문에 그냥 사용하면 된다. 결과적으로 viewName만 반환해주면 된다. public interface ControllerV4 { /** * * @param paramMap * @param model * @return viewName */ String process(Map paramMap, Map model); } ControllerV4 인터페이스를 준수하는 컨트롤러도 마찬가지로 viewName만 반환하도록 설정한다. 대신 파라미터로 전달되는 model에 비즈니스 로직을 반영하여야 한다. pub..
서블릿 종속성 제거 다음 코드는 이전 실습에서 Front Controller를 도입한 컨트롤러의 코드이다. 요청 파라미터 정보는 자바의 Map으로 대신 넘기기만 한다면 HttpServletRequest, HttpServletResponse이 더이상 필요하지 않다. 즉 서블릿 기술이 더이상 필요하지 않다. 그래서 이번에는 서블릿 기술을 사용하지 않고, request 객체를 Model로 사용하는 대신에 별도의 Model 객체인 ModelView를 만들어서 반환하도록 한다. 뷰 이름 중복 제거 앞선 실습에서는 컨트롤러에 /WEB-INF/views/~ 등 jsp 파일(View)의 경로가 중복되어 쓰이는 경우가 많았다. 그래서 컨트롤러에는 View의 가상 경로(논리 이름)를 반환하고, 실제 물리 경로의 이름은 F..
Front Controller 이전에는 공통된 기능이 있다면 매번 중복해서 선언하고 호출해야만 했다. 하지만 Dispatcher Servlet으로 구현된 Front Controller를 사용하면 클라이언트 요청을 Front Controller가 다 받은 다음 요청에 맞는 컨트롤러를 찾아서 호출한다. 1. 클라이언트 요청을 받기 위한 Front Controller 도입 Front Controller는 인터페이스에 의존하면서 다른 컨트롤러들을 편리하게 호출할 수 있다. 다른 컨트롤러(구현체)들은 이 인터페이스를 구현하게 된다. public interface ControllerV1 { void process(HttpServletRequest request, HttpServletResponse response)..
MVC 패턴의 의의 비즈니스 로직은 서블릿처럼 다른 곳에서 처리하고, JSP는 목적에 맞게 HTML로 웹 그리는 것에 집중하는 것이다.(JSP는 화면 렌더링에 최적화되어있다.) MVC 패턴은 하나의 서블릿이나, JSP로 처리하던 것을 컨트롤러(Controller), 뷰(View)라는 영역으로 역할을 나눈 것을 말한다. # Controller HTTP 요청을 받아서 파라미터를 검증하고, 비즈니스 로직을 실행한다. 그리고 뷰에 전달할 결과 데이터를 조회하여 모델에 담는다. # View 뷰는 모델에 담겨있는 데이터를 사용해서 화면을 그리는 일에 집중한다. (대부분 HTML을 생성) # Model 컨트롤러에서 뷰에 출력할 데이터를 담아 둔다. 뷰가 필요한 데이터를 모두 모델에 담아서 전달해주는 덕분에 뷰는 비즈..
GetWriter로 Text를 전달하면서 무수히 많은 HTML을 일일이 쳤다. JSP를 사용하면 선택적으로 Java 코드를 사용할 수 있다. # 회원 추가 JSP 먼저 회원을 추가하는 페이지를 jsp로 작성한 것이다. username: age: 전송 # 회원 저장 JSP new-form.jsp로부터 전달된 username과 age를 저장한다. 서블릿 코드와 동일한 로직을 삽입한다. 성공 id username age 메인 서블릿과 JSP의 한계 JSP 덕분에 뷰를 생성하는 HTML 작업이 매우 깔끔해졌다. 코드의 상위 절반은 비즈니스 로직, 나머지 하위 절반은 HTML로 유저에게 보여주기 위한 뷰 영역이다. 하지만 조금 더 큰 프로젝트라면 JSP 코드가 훨씬 복잡해지고, 머지 시 컨플릭 관리도 어려울 것이다.
실습에 앞서 회원 정보는 String: username과 int: age이며, 기능은 회원 저장 및 조회이다. 우선 회원 관리를 위해 Member라는 도메인 객체와 MemberRepository라는 저장소를 만든다. @Getter @Setter public class Member { private Long id; private String username; private int age; // 기본 생성자 public Member() { } public Member(String username, int age) { this.username = username; this.age = age; } } static 영역에 객체 인스턴스를 하나 미리 생성해서 올려놓는다. 해당 객체 인스턴스가 필요하면 오직 getI..