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

피로한 기린님의 프로필 이미지
피로한 기린

작성한 질문수

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

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

세션은 요청 당 하나만 만들어지는건가요?

해결된 질문

작성

·

814

0

SessionManager에서 직접 개발한 세션은 createSession() 메서드로 여러 개의 세션을 만들어서 sessionStore에 저장할 수 있는 것으로 보이는데요

 

HttpSession을 이용하기 위해 HttpServletRequest의 getSession() 메서드 호출 시 기존 세션이 있다면 생성하지 않고 기존 세션을 가져오는 것으로 이해했습니다.

그러면 2개 이상의 세션을 생성할 수 없고 요청 당 하나의 세션만 만들수 있는 건가요??

 

질문 하나 더 드리자면 HttpServletRequest의 getSession() 호출 시 세션 ID는 자동으로 생성되고, 세션 Name과 Value는 setAttribute로 설정해야 하는 것이 맞나요? 그렇다면 세션과 세션 ID는 1개만 생성되지만 세션 Name과 Value를 여러 개 설정하는 것이 맞는 것인지요??

 

머리 속이 복잡해서 질문드립니다. 읽어주셔서 감사합니다.

 

답변 2

0

안녕하세요. 피로한 기린님, 공식 서포터즈 코즈위버입니다. AI 답변에 더하여 답변 드립니다.

일반적으로 클라이언트와 서버 사이의 세션은 한 개입니다.아주 특수한 경우 서버-클라이언트 사이에 여러개의 세션이 존재할 수는 있습니다. 가령 클라이언트가 크롬과 사파리로 네이버 서버에 로그인 하는 경우, 크롬에서 로그인하여도 사파리에서는 로그인 처리가 되지 않지요. 이 경우에는 브라우저별로 각각 다른 세션을 사용한다고 할 수 있습니다. 검색해보니 브라우저의 창 별로 탭 별로 별도로 관리하는 경우도 있다고 하는데, 이렇게 까지 별도로 분리하여 관리하는 경우는 실제로 경험해보진 못했습니다 :)

추가 질문에 답변 드리면, 한 개의 세션내에 여러개의 값을 저장할 수 있습니다. 다만 세션은 한 번 생성하면 대체로 20~30분 동안 서버에 잔존하는 리소스이기에(로그아웃을 꼬박꼬박 눌러주는 클라이언트가 적습니다 ㅠㅠ), 너무 큰 값(너무 많은 값 혹은 너무 긴 문자열)을 보관하는걸 권하지는 않습니다.

감사합니다.

답변 감사합니다!!!

0

안녕하세요, 인프런 AI 인턴이에요. 세션에 대한 질문이시군요.

기본적으로 HTTP 프로토콜은 상태를 유지하지 않기 때문에 세션을 이용하여 상태를 유지할 수 있습니다. 보통 브라우저와 서버 간의 세션은 클라이언트가 서버에 요청을 보낼 때 생성되며, 요청 당 하나의 세션이 생성된다고 이해하시면 됩니다.

HttpSession의 경우, getSession() 메서드를 호출하면 기존 세션이 있다면 그 세션을 반환하고 없다면 새로운 세션을 생성합니다. 따라서 요청 당 하나의 세션이 생성되는 것이 맞습니다. 여러 개의 세션을 생성하고 싶다면 createSession() 메서드를 사용하시면 됩니다.

또한, HttpSession 객체에는 세션 ID와 세션 Name, 그리고 Value를 저장할 수 있는데, 세션 ID는 자동으로 생성되고 getSession() 메서드를 호출할 때마다 세션 ID가 유지됩니다. 세션 Name과 Value는 클라이언트가 원하는 값으로 설정하면 됩니다. 세션 ID는 1개로 생성되고 세션 Name과 Value는 여러 개 설정하실 수 있습니다.

혹시 더 궁금한 점이 있으시면 언제든지 질문해주세요. 수고하세요!

"요청 당 하나의 세션이 생성된다고 이해하시면 됩니다."의 내용과

"여러 개의 세션을 생성하고 싶다면 createSession() 메서드를 사용하시면 됩니다."의 내용이 상충되는 것 같습니다.

그리고 HttpServletRequest 인터페이스에 createSession() 메서드같이 세션을 생성하는 메서드가 따로 없는 것 같은데 어떻게 여러 개의 세션을 생성한다는 것인지요??

피로한 기린님의 프로필 이미지
피로한 기린

작성한 질문수

질문하기