강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

코딩먹는하마님의 프로필 이미지
코딩먹는하마

작성한 질문수

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

로그인 처리하기 - 서블릿 HTTP 세션1

반환되는 세션안에는 어떤게 있나요?

작성

·

321

·

수정됨

2

<질문>

이미 있는 test로 로그인한다고 가정해보겠습니다

그러면 loginMember의 로그를 찍으면 아래와 같이 되고,

loginMember= Member(id=1, loginId=test, name=테스터, password=test!)

request.getSession()을 하면

HttpSession session = request.getSession();

request의 쿠키정보에서 얻어온 JSESSIONID값으로 Session들을 모아둔 Session저장소에서 동일한 sessionId(=JSESSIONID) 값이 있는지 찾습니다.

그다음 동일한 sessionId가 있으므로 해당 Session을 반환하는 데 이때 이 세션안에는 어떤게 있는 건가요??

제가 생각한건 두개입니다.

1. JSESSIONID와 Value가 session에 들어있는경우

(session={"JSESSIONID": Value})

그러면

session.setAttribute(SessionConst.LOGIN_MEMBER, loginMember);

위 코드에서 초기화를 해주고,

세션 파일은 해시(hash)값으로 생성하니까

session={"JSESSIONID": Value, "SessionConst.LOGIN_MEMBER": loginMember}

이런식으로 HttpSession안에 공존해서 있는 경우

그래서 클라이언트에게 응답할 때 이 세션안에 있는 JSESSIONID를 쿠키에 직접 넣어준다

2. session 안에 아무것도 없는 경우

이 세션은 사용자 test를 구분하기 위한 객체일뿐 session_test(test에 대한 세션)에 아무값이 없다(그냥 빈 객체)

그래서 아래코드를 하게되면

session.setAttribute(SessionConst.LOGIN_MEMBER, loginMember);

session={"SessionConst.LOGIN_MEMBER": loginMember} 이 된다.

그래서 클라이언트에게 응답할 때 세션저장소에서 이 세션의 JSESSIONID를 찾아서 쿠키에 넣어준다

제가 생각한 것 중에 답이 있는 지 궁금합니다.

답변주시면 정말 감사하겠습니다.

아래글을 참고 했습니다.

https://www.inflearn.com/questions/520956/%EC%BB%A4%EB%AE%A4%EB%8B%88%ED%8B%B0-%EB%8B%B5%EB%B3%80-%EA%B8%80-%EB%B3%B4%EB%A9%B4%EC%84%9C-httpsession-%EB%8F%99%EC%9E%91-%EC%9B%90%EB%A6%AC-%EC%A0%95%EB%A6%AC%ED%96%88%EB%8A%94%EB%8D%B0-%EB%A7%9E%EB%8A%94%EC%A7%80-%ED%99%95%EC%9D%B8%ED%95%B4%EC%A3%BC%EC%84%B8%EC%9A%94

답변 1

0

안녕하세요, 코딩먹는하마 님. 공식 서포터즈 y2gcoder 입니다.

간단하게 말씀드리자면 세션 저장소에는 Map<JSESSIONID, Map<String, Object>> 형태로 저장되어있다고 생각하시면 됩니다.

그래서 JSESSIONID로 해당하는 사용자의 세션을 가져오고 session.getAttribute(key)로 해당 키 값에 저장되어 있는 value를 불러올 수 있는 것입니다.

자세한 것은 HttpSession 인터페이스와 구현체 중 StandardSession 을 살펴보시면 될 것 같습니다.

감사합니다.

코딩먹는하마님의 프로필 이미지
코딩먹는하마

작성한 질문수

질문하기