• 회원가입
  • 로그인
  • 구글아이디로 로그인

[web] (세션/쿠키/스토리지/테이블) 방식 장단점

1,685  

(세션/쿠키/스토리지/테이블) 방식 장단점

[질문]

그누보드5 (테마/게시판스킨)을 사용자가 ajax 이용해 선택 가능 시, (세션변수 생성 / 쿠키변수 생성 /스토리지에 저장 / 테이블에 저장) 4가지 방식 중 어떤 방식이 가장 좋나요?

 


[답변]

상황에 따라 다르며, 각 방식의 장단점 고려하여 적절한 방식을 선택 권장.


1. 세션변수 생성 방식 

서버 측에서 세션 객체 생성해 해당 세션에 정보 저장함. 사용자의 브라우저에서 세션 ID를 쿠키로 전송하여 세션 객체를 식별함.

  • 장점: 서버 측에서 관리하기 때문에 보안이 우수함. (브라우저 종료 시 세션도 함께 종료되기 때문에 보안에 더욱 강함.)
  • 단점: 서버 메모리 사용하므로 서버 부하 발생 가능.


2. 쿠키변수 생성 방식 

클라이언트 측에서 쿠키 생성해 정보 저장함. 쿠키는 브라우저가 관리함.

  • 장점: 쿠키 이용하면 서버 부하를 줄일 수 있음. 또한, 쿠키는 브라우저가 관리하기 때문에 클라이언트 측에서 자유롭게 사용 가능.
  • 단점: 쿠키는 브라우저에 저장되기 때문에 보안이 취약함. 또한, 쿠키 크기는 작기 때문에 많은 정보 저장에는 부적합

  

3. 스토리지에 저장 방식

HTML5에 추가된 기능으로, 클라이언트 측에서 로컬 스토리지나 세션 스토리지를 사용하여 정보를 저장함. 
  • 장점: 쿠키보다 보안 우수. 또, 크기 제한 없어 많은 정보 저장 가능.
  • 단점: HTML5 미지원 브라우저에서는 사용 불가.

 

4. 테이블에 저장 방식

서버 측의 데이터베이스 테이블에 정보를 저장함. 
  • 장점: 서버 측에서 관리하므로 보안 우수. 또한, 정보를 영구적으로 보존 가능.
  • 단점: 서버 부하 가능성 존재함. 또, DB 접근 시간 증가 가능성 있음.

 

따라서, 정리하면 아래와 같음.

  1. 사용자 선택 스킨 정보 식별이 목적이면, 쿠키나 스토리지에 저장.
  2. 보안이 중요하면 세션 변수나 테이블에 저장
  3. 그러나, 많은 정보 저장 경우에는 세션 변수나 테이블에 저장
  4. 또한, 사용자가 로그인한 상태에서만 스킨 선택 기능 사용하려면, 세션 변수나 테이블에 저장.
  5. 브라우저 종료 후에도 정보 유지하려면, 스토리지에 저장.


마지막으로, 어떤 방식 선택하든, 보안 고민은 필수임.

  1. 중요 정보는 암호화 저장하거나, 세션/쿠키 유효시간을 짧게 설정.
  2. 또한, XSS/CSRF 같은 보안 취약점 예방 위한 대책도 반드시 강구.

 

 



분류 제목
web 스킨, 테마, 빌더, 플러그인, 코어 차이점 (= 개념비교) 1
web 유챗 - 얼리기/녹이기 기능
web PC에서 모바일모드 확인법
web 크롬 앗이런 (= 앗! 이런) 에러해결 ★ (= 크롬 재설치실패 에러해결)
web IE11 이하 (= 익스플로러 하위브라우저) 이미지 엑박 에러 원인/해결
web 구글맞춤검색 광고제거
web 유튜브 (유투브,유투버) 조회수당 (=뷰당) 평균수익공개
web 윈도우10 - 윈도우디펜더 아이콘 색깔 변경 (노란색 → 녹색)
web 크롬 - 캐시 만료 설정 코드 + 캐시 새로고침 (= Clear Cache 크롬 확장 프로그램) ※ 클리어 …
web 무료홈페이지빌더 사이트모음 ★ (=빌더추천 = 빌더종류 = 홈페이지빌더모음 = 프레임워크종류)
web 줄바꿈 (= 개행) : LF (Line Feed)와 CR (Carriage Return)
web 위키 다운로드 주소 모음 (Wiki Download Site Collection)
web 윈도우10 - 이모지 (Emoji) (입력법 + 웹에 적용) 2
web 일본 (보이콧・불매운동) 배너 달기 (= 노재팬배너 = Nojapan Boycott Banner)
web 깔끔한 코딩 가이드
web 스팸차단/스팸방어/스팸관리/스팸삭제/스팸제거/스팸해결/스팸방지/스패머차단 (프로그램 다운로드 + 그누보드5 …
web 초보자가 빨리 코딩실력 키우는 법 ^!~
web 도메인포워딩 개념 및 종류 (고정포워딩, 유동포워딩)
web 커널, 쉘, SSH, 콘솔, 터미널 개념 구분 + 사용중인 쉘종류 확인
web SSH 추천 콘솔 다운로드 (PuTTY , Xshell , poderosa , MobaXterm , Sec… 설문 중
7/19
목록
찾아주셔서 감사합니다. Since 2012