두 번째 내용은 스프링 프레임워크입니다.
@Configuration
@Import(CompanyConfig.class)
public class BeanConfig {
@Bean
public WorkManager employee() {
return new Employee();
}
@Bean
public WorkManager boss() {
return new Boss();
}
@Bean
public WorkService yourWorkService() {
WorkService workService = new WorkService();
workService.setWorkManager(employee());
return workService;
}
@Bean
public WorkService myWorkService() {
WorkService workService = new WorkService();
workService.setWorkManager(boss());
return workService;
}
}
@Controller
public class IndexController {
@RequestMapping("/")
public ModelAndView home() {
ModelAndView mv = new ModelAndView("home");
mv.addObject("title", "Jpub Spring WEB");
mv.addObject("today", new Date().toString());
System.out.println("index 컨트롤러");
return mv;
}
}
5. 인터셉터
- 컨트롤러가 요청을 처리하기 전 혹은 후에대에 로직을 추가
- filter : Dispatcher Servlet 실행 이전에 동작 / Interceptor : Dispatcher Servlet 실행 이후 적용
public class ExecuteTimeInterceptor extends HandlerInterceptorAdapter {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
long startTime = System.currentTimeMillis();
request.setAttribute("startTime", startTime);
String reqUri = request.getRequestURI();
System.out.println("reqUri: " + reqUri);
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
long startTime = (Long)request.getAttribute("startTime");
long endTime = System.currentTimeMillis();
long executeTime = endTime - startTime;
request.setAttribute("executeTime", executeTime);
System.out.println("[" + handler + "] executeTime : " + executeTime + "ms");
}
}
내용 출처 : 윤석진. (2018). 스프링 부트로 배우는 자바 웹 개발. 주식회사 제이펍