[study] JSESSIONID와 tracking-mode 설정 방식 [클라이언트와 세션 ID를 주고받는 방식을 설정하는 속성]

2025. 3. 18. 19:42·◈ Study/기초튼튼 개발지식🥔
728x90


- JSESSIONID와 tracking-mode 설정 방식

tracking-mode는 Java EE (Jakarta EE) 웹 애플리케이션에서 세션 ID를 클라이언트와 주고받는 방식을 설정하는 속성이다. 즉, JSESSIONID를 어떻게 전달할지 결정하는 역할.

- tracking-mode 설정 방식

1) cookie (기본값)

  • JSESSIONID를 쿠키를 통해 전달하는 방식
  • 가장 일반적이고 보안이 우수함
  • 브라우저가 쿠키를 차단하면 세션이 유지되지 않음

- 설정 방법 (web.xml에서 설정)

<session-config>
    <tracking-mode>COOKIE</tracking-mode>
</session-config>

2) url (URL 리라이트)

  • JSESSIONID를 URL에 추가하는 방식
  • 쿠키를 지원하지 않는 환경에서도 세션 유지 가능
  • 하지만 보안 취약점(Session Hijacking 등)이 있음
예제 URL (URL 리라이트 사용 시)
https://example.com/home;jsessionid=ABC123XYZ

- 설정 방법 (web.xml에서 설정)

<session-config>
    <tracking-mode>URL</tracking-mode>
</session-config>

3) ssl (HTTPS 세션 ID)

  • SSL 세션을 통해 세션을 유지하는 방식
  • JSESSIONID를 쿠키나 URL에 저장하지 않고, SSL 자체 세션을 활용
  • 클라이언트가 세션을 계속 유지하려면 HTTPS를 사용해야 함
  • 사용하려면 서버가 SSL을 지원해야 함

- 설정 방법 (web.xml에서 설정)

<session-config>
    <tracking-mode>SSL</tracking-mode>
</session-config>

4) Java 코드로 tracking-mode 설정

import javax.servlet.SessionTrackingMode;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebListener;
import javax.servlet.ServletContextListener;

@WebListener
public class SessionConfigListener implements ServletContextListener {
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        ServletContext context = sce.getServletContext();
        context.setSessionTrackingModes(Collections.singleton(SessionTrackingMode.COOKIE)); // 쿠키 방식
    }
}

- 어떤 tracking-mode를 써야 할까?

tracking-mode 설명 장점 단점
COOKIE JSESSIONID를 쿠키로 전달 보안이 좋음, 추천 방식 쿠키 차단 시 문제 발생
URL JSESSIONID를 URL에 포함 쿠키 미지원 환경에서 사용 가능 세션 하이재킹 위험
SSL HTTPS 세션을 활용 쿠키/URL 없이 안전한 세션 유지 HTTPS 필수, 설정이 복잡함

 


 

- 추천 설정

  • 가능하면 COOKIE 방식 사용
  • 보안상 URL 방식은 가급적 사용하지 않기
  • HTTPS 기반이라면 SSL 방식 고려

 

[study] URL 리라이트(URL Rewriting)란 무엇인가? [JSESSIONID를 URL에 포함하는 방식]

- URL 리라이트(URL Rewriting)란 무엇인가? 쿠키를 사용할 수 없는 환경에서도 세션을 유지하기 위해 JSESSIONID를 URL에 포함하는 방식- 왜 URL 리라이트를 사용하는 걸까?1) 쿠키 비활성화 환경 지원

yermi.tistory.com


728x90
'◈ Study/기초튼튼 개발지식🥔' 카테고리의 다른 글
  • [study] Object와 JSON의 차이 [JSON.stringify()의 필요성]
  • [study] 바닐라 자바스크립트란 무엇인가? [Vanilla JS, 아무 라이브러리나 프레임워크 없이 순수한 기본 JavaScript만 사용한 코드]
  • [study] URL 리라이트(URL Rewriting)란 무엇인가? [JSESSIONID를 URL에 포함하는 방식]
  • [study] JSESSIONID란? [Java EE 기반 웹 애플리케이션에서 세션을 식별하는 고유한 ID]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    html
    Error Note
    BOJ
    Database
    jsp
    코딩
    SQL
    javascript
    Java
    백준
    백준 티어
    spring
    Oracle
    CSS
    꿀팁
    코딩 테스트
    Project
    자바스크립트
    일상
    프로그래밍
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[study] JSESSIONID와 tracking-mode 설정 방식 [클라이언트와 세션 ID를 주고받는 방식을 설정하는 속성]
상단으로

티스토리툴바