@RequestParam
- RequestParam annotation은 key=value 형태로 화면에서 넘어오는 파라미터를 맵핑된
메소드의 파라미터로 지정해준다.
- 주로 get 방식으로 들어오는 request에서 사용한다.
- 필수 요건이 아닐 경우, @RequestParam(value="id", required="false")와 같이 옵션을 주고
사용할 수 있다.
----------------------------------------------------------------------------------
@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;
}
댓글 없음:
댓글 쓰기