728x90
HTTP 는 클라이언트가 누구인지 매번 확인해야하는 특성을 보완하기 위해 쿠키와 세션을 사용한다.
쿠키(Cookie)
[정의 및 특징]
- 클라이언트(브라우저/개인 컴퓨터)로컬에 저장되는 키와 값이 들어있는 작은 데이터 파일
- 사용자 인증이 유효한 시간을 명시할 수 있으며, 유효 시간이 정해지면 브라우저가 종료되어도 인증이 유지
- 클라이언트 상태정보를 로컬(브라우저)에 저장 후 참조
- 사용자가 따로 요청하지 않아도 브라우저가 Request 시에 Request Header를 넣어 자동으로 서버에 전송
[동작 방식]
- 클라이언트가 페이지를 요청
- 서버에서 쿠키 생성
- HTTP 헤더에 쿠키를 포함시켜 Response
- 브라우저가 종료되어도 쿠키 만료 기간이 있다면 클라이언트에서 보관
- 같은 요청을 할 경우 HTTP 헤더에 쿠키를 함께 보냄
* 서버에서 쿠키를 읽어 이전 상태 정보를 변경할 필요가 있을 때 쿠키를 업데이트하여 변경된 쿠키를 HTTP 헤더에 포함시켜 응답
[예시]
- 로그인 시 '아이디와 비밀번호를 저장하시겠습니까?' 메세지
- 쇼핑몰 장바구니 기능
세션(Session)
[정의 및 특징]
- 쿠키를 기반으로 하고 있지만, 사용자 정보 파일을 브라우저에 저장하는 쿠키와 달리 서버 측에서 관리
- 서버에서는 클라이언트를 구분하기 위해 세션ID를 부여하여 웹 브라우저가 서버에 접속해서 브라우저를 종료할 때까지 인증상태 유지
- 사용자에 대한 정보를 서버에 두기 때문에 쿠키보다 보안에 좋지만 사용자가 많아질 수록 서버 메모리를 많이 차지해 성능저하 발생 가능성 ↑
[동작 방식]
- 클라이언트가 서버에 접속 시 세션ID를 발급 받음
- 클라이언트는 세션ID에 대해 쿠키를 사용해서 저장하고 가지고 있음
- 클라이언트는 서버에 요청할 때, 이 쿠키의 세션ID를 같이 서버에 전달해서 요청
- 서버는 세션ID를 전달 받아서 별다른 작업없이 세션ID로 세션에 있는 클라이언트 정보를 가져와 사용
- 클라이언트 정보를 가지고 서버 요청을 처리하여 클라이언트에게 응답
[예시]
- 로그인 같이 보안 상 중요 작업을 수행할 때 사용
쿠키와 세션의 차이점
*쿠키는 서버의 자원을 전혀 사용하지 않으며, 세션은 서버의 자원을 사용한다. 즉 상태정보의 저장 위치가 다르다.
1. 보안
- 쿠키는 클라이언트 로컬에 저장되기 때문에 변질되거나 request에서 스니핑 당할 우려가 있어 보안에 취약
- 세션은 쿠키를 이용해서 세션ID만 저장하고 그것으로 구분해서 서버에서 처리하기 때문에 비교적 보안성이 좋음
2. 라이프 사이클
- 쿠키도 만료시간이 있지만 파일로 저장되기 때문에 브라우저를 종료해도 계속해서 정보가 남아 있을 수 있다.
- 세션도 만료기간을 정할 수 있지만 브라우저가 종료되는 만료시간에 상관없이 삭제
-> 크롬에서 다른 탭을 사용해도 세션은 공유된다. 다른 브라우저를 사용하게 되면 다른 세션을 사용할 수 있다.
3. 속도
- 쿠키에 정보가 있기 때문에 서버에 요청시 속도가 빠름
- 세션은 정보가 서버에 있기 때문에 처리가 요구되어 비교적 속도가 느림
※ 쿠키 사용 이유?
세션은 서버의 자원을 사용하기 때문에 무분별하게 만들다 보면 서버의 메모리가 감당할 수 없어질 수 있고 속도가 느려질 수 있기 때문에, 쿠키의 사용이 유리한 경우가 있음
728x90
'WEB' 카테고리의 다른 글
[WEB] GET과 POST의 차이 (0) | 2023.12.11 |
---|---|
라이브러리(Library) VS 프레임워크(Framework) (0) | 2023.10.25 |
[WEB] SPA, CSR, SSR 차이 (0) | 2023.10.19 |
[WEB] 웹페이지에 스크롤 애니메이션 만들기 IntersectionObserver() (0) | 2023.01.16 |
[Git / GitHub] Git으로 GitHub에 프로젝트 올리는 법 (0) | 2022.12.28 |