Script

쿠키와 세션의 차이 본문

CS

쿠키와 세션의 차이

scripter. 2022. 11. 11. 07:51

쿠키란?

  • 쿠키는 로컬에 저장되는 키와 값이 들어있는 데이터 파일이다.
  • 사용자 인증이 유효한 시간을 명시할 수 있으며, 유효 시간이 정해지면 브라우저가 종료되어도 유지된다.
  • 쿠키는 클라이언트의 상태 정보를 로컬에 저장했다가 참조한다.

쿠키의 사용 예

  • 자동로그인
  • 쇼핑몰의 장바구니
  • 팝업에서 "오늘 더 이상 이 창을 보지 않음" 체크

세션이란?

  • 세션은 쿠키를 기반으로 하나, 브라우저에 저장하는 쿠키와는 달리 세션은 서버 측에서 관리한다.
  • 서버에서는 클라이언트를 구분하기 위해 세션 ID를 부여하며 브라우저를 종료할 때까지 인증상태를 유지한다.
  • 사용자에 대한 정보를 서버에 두기 때문에 쿠키보다 보안에 유리하나, 사용자가 많아질 수록 서버 메모리를 많이 차지하게 된다. ( 동접자가 많을 경우 성능 저하의 요인이 된다.)

세션의 사용 예

  • 금융기관 같이 보안상 중요한 작업을 수행할 때 사용

정리- 쿠키와 세션의 차이

  • 쿠키와 세션은 비슷한 역할을 하며, 동작원리도 비슷하다. (세션도 결국 쿠키를 사용하기 때문)
  • 가장 큰 차이점은 사용자 정보가 저장되는 위치이다. 쿠키는 서버의 자원을 전혀 사용하지 않으며, 세션은 서버의 자원을 사용.
  • 보안 면에서 세션이 더 우수한 이유는, 쿠키는 클라이언트의 로컬에만 저장되기 때문에 변질되거나 request에서 스니핑 당할 우려가 있어서 보안에 취약하지만, 세션은 쿠키를 이용해서 sessionId만 저장하고 그것으로 구분해서 서버에서 처리하기 때문이다.
  • 라이프 사이클 - 쿠키도 만료시간이 있지만 파일로 저장되기 때문에 브라우저를 종료해도 계속해서 정보가 남아있을 수 있다. 반면, 세션도 만료시간을 정할 수 있지만 이와 상관없이 브라우저가 종료되면 삭제된다.
  • 속도 - 쿠키는 로컬에 정보가 있기 때문에 서버에 요청시 속도가 빠르고, 세션은 정보가 서버에 있기 때문에 처리가 요구되어 비교적 느린 속도를 가진다.

 

참고 블로그

https://interconnection.tistory.com/74

'CS' 카테고리의 다른 글

HTTP와 HTTPS의 차이  (0) 2022.11.23
SSR과 CSR / SPA와 MPA  (0) 2022.11.14
RESTful API란  (0) 2022.11.09
브라우저에 'naver.com'을 입력하면 일어나는 일  (0) 2022.11.01
공개 키 암호 기법과 닫힌 자물쇠  (0) 2022.08.11
Comments