2010년 11월 15일 월요일

@Controller

@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;
    }
   
}

 

댓글 없음:

댓글 쓰기