티스토리 뷰

반응형

스프링 MVC 컨트롤러 (Controller)

기본적인 흐름은 client가 요청을 하면, @Controller에 진입한다.

컨트롤러는 요청에 대한 작업을 수행하고, 뷰쪽으로 데이터를 전달한다.

 

컨트롤러 클래스 제작 순서

  • @Controller를 이용해서 클래스를 생성한다.

  • @RequestMapping을 이용해, view의 요청 경로 지정한다.

  • 요청 처리 메소드(로직) 구현한다.

  • 뷰 이름 리턴한다.

예를들어,

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
@Controller // 컨트롤러 지정
public class HomeController {
    
    // 뷰의 요청 경로 지정
    @RequestMapping(value = "/", method = RequestMethod.GET)
    public String home(Locale locale, Model model) {
        
        // 로직 수행
        logger.info("Welcome home! The client locale is {}.", locale);
        Date date = new Date();
        DateFormat dateFormat = DateFormat.getDateTimeInstance(DateFormat.LONG, DateFormat.LONG, locale);
        String formattedDate = dateFormat.format(date);
        
        // Model 객체를 이용해서, view로 Data 전달
        model.addAttribute("serverTime", formattedDate );
        
        return "home"// 뷰 파일 리턴
    }
}
 
 
출처: https://hongku.tistory.com/116 [IT에 취하개 :: 취미로 하는 개발]
cs

 

View의 요청 경로(Path) 설정하기

@RequestMapping 

어노테이션을 이용해서, view 폴더안의 내가 목표로 하는 view의 경로(path)를 넣는다.

예를들어, view.jsp가 아래와 같은 경로를 가질때

 

 

 

 

 

 

 

 

 

 

 

 

아래와 같이 /board/view 라고 설정한다.

 
@RequestMapping("/board/view") // 요청경로(path)

그리고, return 값도 똑같이 board/view로 설정 한다.

return "board/view";  // 뷰페이지 이름

 

Model 객체 사용법

Model 객체를 파라미터로 받아서 데이터를 뷰로 넘길 수 있다.

1
2
3
4
5
6
7
8
9
10
11
@RequestMapping("/board/view")
public String view(Model model) {
    
    // 데이터만 설정이 가능
    model.addAttribute("id""hongku");
    
    return "board/view";
}
 
 
출처: https://hongku.tistory.com/116 [IT에 취하개 :: 취미로 하는 개발]
cs

Model 객체를 파라미터로 받는다.

model.addAttribute("변수이름", "변수에 넣을 데이터값");

model.addAttribute를 이용해서, 넘길 데이터의 이름과 값을 넣는다. 그러면, 스프링은 그 값을 뷰쪽으로 넘겨준다.

 

${변수이름}

뷰(.jsp 파일)에서는 ${}를 이용해서 값을 가져온다. 예를들어,

 

당신의 ID는 ${id} 입니다.

 

 

 

 

 

 

 

 

 

 

 

 

 

 

ModelAndView 객체 사용법

Model 객체와 크게 다르지 않다.

1
2
3
4
5
6
7
8
9
10
11
12
13
@RequestMapping("/board/content")
public ModelAndView content() {
 
    // 데이터와 뷰를 동시에 설정이 가능
    ModelAndView mv = new ModelAndView();
    mv.setViewName("/board/content"); // 뷰의 이름
    mv.addObject("data""12341234"); // 뷰로 보낼 데이터 값
    
    return mv;
}
 
 
출처: https://hongku.tistory.com/116 [IT에 취하개 :: 취미로 하는 개발]
cs

반환값으로 ModelAndView 객체를 반환한다. ModelAndView 객체를 선언 및 생성한다. 뷰의 이름을 설정해줘야 하는데, setViewName() 메소드를 이용한다.

 

mv.setViewName("뷰의 경로");

데이터를 보낼때는 addObject() 메소드를 이용한다.

 

mv.addObject("변수 이름", "데이터 값");

그리고,

return mv;

ModelAndView 객체를 반환한다.

jsp도 똑같이 ${}를 이용한다.

 

Data : ${data}

 

 

 

 

 

 

 

 

 

 

 

 


출처: https://hongku.tistory.com/116 [IT에 취하개 :: 취미로 하는 개발]

반응형
반응형