inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

세션 관련 질문 있습니다!

599

전한울

작성한 질문수 21

1

1. 앞 강의에서 세션 관련해서는 서버에서 세션 저장할때 랜덤

값과 맴버 객체만 있으면 될 거 같은데 굳이 SessionConst.LO

GIN_MEMBER값은 왜 쓰이고 어디에 쓰는지 모르겠습니다.

2. 그냥 session.setAttribute하면 addCookie 할 필요없이 

알아서 클라이언트한테 세션 값이 가는 건가요??

MVC spring

답변 1

4

David

안녕하세요. 전한울님, 공식 서포터즈 Taewon David Hwang입니다:)
.

1. Session ID는 사용자를 식별할 수 있는 값이며 또한 Session을 식별할 수 있는 값입니다. 요청한 사용자가 보낸 Session ID를 가지고 있는 Session을 불러옵니다. 해당 세션 객체는 attributes라는 Map 타입의 저장공간을 가지고 있으며 이는 key, value 형태로 관리됩니다. 이때 SessionConst.LOGIN_MEMBER는 Key에 해당하고 Value는 loginMember가 되는 것입니다. 이후 동일한 사용자에 의해 서버로 요청이 들어왔을 때 이 사용자가 로그인한 사용자인지 아닌지 확인하기 위해서는 Session ID를 확인하고 해당 Session ID와 일치하는 Session을 불러와 Session 내 Attributes Map에서 SessionConst.LOGIN_MEMBER Key를 사용하여 loginMember Value를 가져오게 됩니다.

2. session.setAttribute는 쿠키에 세션 값을 저장하는 것이 아닙니다. session id는 톰캣이 쿠키에 저장하여 사용자에게 전달합니다.

.
감사합니다.

0

kkt169

1번 답변에 대하여 질문이 있습니다.

HttpSession을 사용하기 전에는,

UUID로 생성한 랜덤값을 세션 키로 사용하였는데,

HttpSession을 사용한 버전3에서는 언급하신 것 처럼 SessionConst.LOGIN_MEMBER 가 세션 키로 사용된다고 이해하였습니다. 

그러면 쿠키 데이터 중 이름이 JSESSIONID  인 value 인 랜덤값은 HttpSession을 사용하기 전과 달리 세션 키로 사용되지 않는다는 의미로 이해가 되는데요, 

그러면 이 랜덤값이 서버에서 별도의 로직을 통해  SessionConst.LOGIN_MEMBER와 대응되고, 이 SessionConst.LOGIN_MEMBER를 키로 하여 세션 값에 접근하는 것인지 궁금합니다.

항상 좋은 답변 감사합니다.

rJSESSIONID

1

David

jsessionId는 별도의 세션 저장소에서 세션을 꺼낼 수 있는 key가 됩니다.

LOGIN_MEMBER와 대응하지 않습니다.

jsessionId를 통해 특정 사용자를 위한 세션(key, value 저장소)을 가져오고,

가져온 세션의 키로 LOGIN_MEMBER를 사용하여 loginMember 값을 가져오는 것입니다.

이미지 업로드와 db 트랜잭션 묶는법

0

40

1

Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4

0

45

2

MessageSourceTest 코드

0

46

1

인터셉터 에러 설정

0

47

1

resolveArgument()메서드 질문

0

54

1

43강 검증1 에서 실패 로직 관련 질문있습니다.

0

52

2

타임리프 3.X 버전 rendering, serializer 에러 해결 방법

2

130

3

스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ

0

86

3

pdf 오타 문의

0

54

1

ItemUpdateForm 검증 관련 질문입니다.

0

46

1

22page 링크 주소 변경

0

55

2

특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문

0

52

1

섹션3번 수업에 대한 질문입니다.

0

78

2

@Autowired 보다 더 좋은 방법이 어떤 걸까요?

0

84

2

타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.

0

63

1

자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다

0

140

3

스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문

0

62

1

톰캣 에러 페이지가 안보입니다.

0

98

2

apiEceptionController에서 센드 에러 호출하면 안되는지?

0

80

1

세션 타임아웃시 쿠키 삭제 방법이 없나요?

0

116

2

ApiExceptionController 질문드립니다.

0

62

1

셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?

0

64

1

MemberRepository 필드의 fianl 선언 유무

0

83

2

혹시 index.html 에서는 fragment 사용이 안되는건가요

0

57

1