728x90
반응형

JWT란 무엇인가?

JWT는 JSON Web Token의 약자로, JSON 형태의 데이터를 네트워크를 통해 안전하게 전송하기 위해 설계된 방식입니다. JWT는 마치 편지와 같은 구조를 가지고 있습니다:

  • 봉투 (Header): 토큰의 타입과 사용된 알고리즘 정보
  • 편지지 (Payload): 실제 전달하려는 데이터 (Claims)
  • 서명 (Signature): 토큰의 유효성을 검증하기 위한 서명

 

JWT의 구조

JWT는 세 부분으로 구성되며, 각 부분은 Base64로 인코딩되어 점(.)으로 구분됩니다:

header.payload.signature

 

 

JWT의 핵심: 서명(Signature)

서명은 JWT의 무결성을 보장하는 핵심 요소입니다. 서명 과정은 다음과 같습니다:

  • 비밀키(Secret Key)를 사용
  • 헤더와 페이로드를 입력으로 사용
  • 지정된 알고리즘(예: HMAC)으로 서명 생성

 

JWT의 활용 분야

JWT는 다양한 분야에서 활용되지만, 가장 흔한 용도는 인증(Authentication)입니다. 주요 활용 분야는 다음과 같습니다:

  • 인증
  • 정보 공유
  • 권한 부여
  • 단일 로그인(SSO)
  • 서버 간 통신

 

JWT 기반 인증 과정

로그인

  • 사용자가 로그인 정보 제공
  • 서버가 정보 확인 후 JWT 생성 및 클라이언트에 전송

인증

  • 클라이언트가 JWT를 서버에 전송
  • 서버가 JWT를 검증
  • 검증 성공 시 요청 처리

JWT의 장점

  • 서버 부하 감소: 세션 저장소가 필요 없음
  • 확장성: 다중 서버 환경에서 유리
  • 클라이언트 측 저장: 필요한 정보를 페이로드에 포함 가능

JWT의 단점

  1. 토큰 크기: JWT는 모든 정보를 자체적으로 포함하므로, 토큰 크기가 상대적으로 클 수 있습니다. 이는 네트워크 대역폭 사용량을 증가시킬 수 있습니다.
  2. 보안 위험: 토큰 탈취: JWT가 탈취되면, 만료되기 전까지 공격자가 사용할 수 있습니다.
  3. 토큰 무효화의 어려움: 일단 발급된 JWT는 만료 전까지 유효하며, 개별 토큰을 즉시 무효화하기 어렵습니다. 이는 보안 문제 발생 시 대응을 어렵게 만들 수 있습니다.
  4. 갱신 로직의 복잡성: 토큰 만료 관리와 갱신 프로세스가 복잡할 수 있습니다.
  5. 상태 저장의 한계: JWT는 기본적으로 무상태(stateless)이므로, 사용자 상태 변경을 실시간으로 반영하기 어려울 수 있습니다.
  6. 암호화 부재: 기본 JWT는 서명은 되지만 암호화되지 않아, 중요한 정보는 페이로드에 포함시키지 말아야 합니다.
  7. 구현의 복잡성: 올바른 JWT 구현과 관리는 복잡할 수 있으며, 잘못 구현 시 보안 취약점이 발생할 수 있습니다.
  8. 만료 시간 설정의 딜레마: 짧은 만료 시간은 보안에 유리하지만 사용자 경험을 해칠 수 있고, 긴 만료 시간은 그 반대입니다.

 

JWT 실습

JWT.io 사이트를 통해 JWT를 직접 생성하고 검증해볼 수 있습니다. 이를 통해 JWT의 구조와 작동 방식을 실제로 확인할 수 있습니다.

 

결론

JWT는 현대 웹 애플리케이션에서 인증과 정보 교환을 위한 효율적이고 안전한 방법을 제공합니다. 그러나 보안을 위해 적절한 사용과 관리가 필요합니다. JWT의 이해는 웹 개발자에게 필수적인 지식이 되어가고 있습니다.

 

출처

https://www.youtube.com/watch?v=36lpDzQzVXs

 

728x90
반응형

+ Recent posts