<5. Session>
참고: [boostcourse full-stack] http://www.edwith.org/boostcourse-web
* 세션
- 클라이언트 별로 서버에 저장되는 정보
- 웹 클라이언트가 서버측에 요청을 보내게 되면 서버는 클라이언트를 식별하는 session id를 생성한다.
- 서버는 session id를 이용해서 key와 value를 이용한 저장소인 HttpSession을 생성한다.
- 서버는 session id를 저장하고 있는 쿠키를 생성하여 클라이언트에 전송한다.
- 클라이언트는 서버측에 요청을 보낼때 session id를 가지고 있는 쿠키를 전송한다.
- 서버는 쿠키에 있는 session id를 이용해서 그 전 요청에서 생성한 HttpSession을 찾고 사용한다.
- 세션 생성 및 얻기
HttpSession session = request.getSession();
HttpSession session = request.getSession(true);
- request의 getSession()메소드는 서버에 생성된 세션이 있다면 세션을 반환하고 없다면 새롭게 세션을 생성하여 반환합니다. => session은 new로 생성하지 않는다.
- 새롭게 생성된 세션인지는 HttpSession이 가지고 있는 isNew()메소드를 통해 알 수 있다.
HttpSession session = request.getSession(false);
- request의 getSession()메소드에 파라미터로 false를 전달하면, 이미 생성된 세션이 있다면 반환하고 없으면 null을 반환(새로 만들지 않음)
- 세션에 값 저장
setAttribute(String name, Object value)
- name과 value의 쌍으로 객체 Object를 저장하는 메소드
- 세션이 유지되는 동안 저장할 자료를 저장한다.
session.setAttribute(이름, 값)
- 세션에 값 조회
getAttribute(String name) 메소드
- 세션에 저장된 자료는 다시 getAttribute(String name) 메소드를 이용해 조회한다.
- 반환 값은 Object 유형이므로 저장된 객체로 자료유형 변환 필요
- 메소드 setAttribute()에 이용한 name인 “id”를 알고 있다면 바로 다음과 같이 바로 조회한다.
String value = (String) session.getAttribute("id");
- 세션에 값 삭제
- removeAttribute(String name) 메소드
- name값에 해당하는 세션 정보를 삭제한다. - invalidate() 메소드
- 모든 세션 정보를 삭제한다.
- javax.servlet.http.HttpSession