@Controller
- Controller annotation으로 Controller interface 및 class의 기능을 간단하게 사용할 수 있다.
- Annotation을 사용하지 않고, Controller를 직접 상속받아 쓰는 경우 필요한 xml 설정을
생략할 수 있다.
- SimpleFormController, MultiActionController 등 Controller의 종류를 명시하지 않고
@Controller 설정만으로 사용할 수 있다.
- xxx-servlet.xml 파일에서 component-scan 으로 web controller가 있는 패키지를 명시해
줌으로써, 별도의 bean 설정을 하지 않아도 @Controller로 등록된 클래스 파일에 대한
bean을 자동으로 생성해준다.
- Controller로 사용하고자 하는 클래스에 @Controller 지정해주면 component-scan으로
자동 등록된다.
----------------------------------------------------------------------------------
@Controller
public class LoginController {
@Autowired
private LoginService loginService;
@Autowired
private SampleService sampleService;
/**
* 사용자로 부터 아이디, 패스워드를 입력받아 인증 성공이면 세션 객체에 계정정보를 담고 사원정보리스트 페이지로 포워딩한다. 인증에
* 실패하면 로그인 페이지로 다시 리턴한다.
*/
@RequestMapping("/loginProcess.do")
public String login(HttpServletRequest request, @RequestParam("id") String id,
@RequestParam("password") String password) {
// TODO [Step 4-1-01]
// LoginService의 authenticate메소드를 이용하여 로긴여부 체크 Account 객체를 리턴 받는다.
Account account = (Account) loginService.authenticate(id, password);
/*
* TODO [Step 4-1-03]
* 가져온 account 객체가 null 아닌 경우
* request.getSession() 메소드를 통해 Session을 구해 UserAccount 이름으로 Session 에
* Attribute로 저장한다. 그리고 "redirect:/loginSuccess.do" 값을 반환한다. null 인경우
* "login" 반환한다.
*/
if (account != null) {
request.getSession().setAttribute("UserAccount", account);
return "redirect:/loginSuccess.do";
} else {
return "login";
}
}
// TODO [Step 4-1-04]
// loginSuccess.do 로 호출된 처리(@RequestMapping(value="/loginSuccess.do", method=RequestMethod.GET) 를 위한
// 메소드(loginSuccess) 를 void 타입의 public 메소드를 만들어라.
@RequestMapping(value = "/loginSuccess.do", method = RequestMethod.GET)
public void loginSuccess() {
}
@RequestMapping("/exception.do")
public String invokeException(@RequestParam("id") String id ) throws Exception {
sampleService.invokeMethodAException();
return null;
}
}
댓글 없음:
댓글 쓰기