[Spring Security] OAuth 2.0을 이용한 인증

2023. 10. 19. 10:11·Web & Android/Spring Security
목차
  1. OAuth
  2. OAuth 2.0
  3. 인증 순서

카카오 로그인 실습 - Web

J219. Spring Boot OAuth2 Google, Naver Login

💡 OAuth 2.0을 이용한 인증

OAuth

  • 외부 서비스의 인증 및 권한 부여를 관리하는 범용적인 프로토콜

OAuth 2.0

  • 모바일에서도 사용 용이
  • 반드시 HTTPS를 사용하므로 보안이 강화됨
  • Access Token의 만료 기간이 생김

→ OAuth 2.0의 인증 방식은 4가지 있음 → 가장 범용적으로 쓰이는 것은 Authorization Code Grant

인증 순서

  • Resource Owner : 일반 사용자
  • Client : 우리가 만든 웹 어플리케이션
  • Authorization Server : 권한 관리 및 Access Token, Refresh Token을 발급해주는 서버
  • Resource Server : OAuth 2.0을 관리하는 서버의 자원을 관리하는 곳
  1. Resource Owner가 Client에게 인증 요청
  2. Client는 Authorization Request를 통해 Resource Owner에게 인증할 수단(Facebook, Google 로그인 url)을 보냄
  3. → Resource Owner는 해당 Request를 통해 인증을 진행
  4. 인증을 완료했다는 신호로 Authorization Grant를 url에 실어 Client에게 보냄
  5. Client는 해당 권한 증서를 Authorization Server에 보냄
  6. Authorization Server는 권한 증서를 확인 후, 유저가 맞다면 Client에게 Access Token, Refresh Token, 그리고 유저의 정보를 발급
  7. Client는 해당 Access Token을 DB에 저장하거나 Resource Owner에게 넘김
  8. Resource Owner가 Resource Server에 자원이 필요하면, Client는 Access Token을 담아 Resource Server에 요청
  9. Resource Server는 Access Token이 유효한 지 확인 후, Client에게 자원을 보냄→ 그 후 다시 Resource Server에 자원을 요청
  10. → 만일 Refresh token도 만료되었을 경우, Resource Owner는 새로운 Authorization Grant를 Client에게 넘겨야 함
  11. → 만일 Access Token이 만료됐거나 위조되었다면, Client는 Authorization Server에 Refresh Token을 보내 Access Token을 재발급 받음
저작자표시 비영리 변경금지 (새창열림)

'Web & Android > Spring Security' 카테고리의 다른 글

[Spring Security] Annotation  (0) 2023.10.19
[Spring Security] SNS 로그인  (0) 2023.10.19
[Spring Security] 카카오 로그인 실습 - Web  (0) 2023.10.19
[Spring Security] Access Token+ Refresh Token을 이용한 인증  (1) 2023.10.19
[Spring Security] Access Token을 이용한 인증  (0) 2023.10.19
  1. OAuth
  2. OAuth 2.0
  3. 인증 순서
'Web & Android/Spring Security' 카테고리의 다른 글
  • [Spring Security] Annotation
  • [Spring Security] SNS 로그인
  • [Spring Security] 카카오 로그인 실습 - Web
  • [Spring Security] Access Token+ Refresh Token을 이용한 인증
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
Jin's Dev Story여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (794)
      • Tools (25)
        • eGovFrame (3)
        • GeoServer (3)
        • QGIS (2)
        • LabelImg (2)
        • Git (6)
        • GitHub (1)
        • Eclipse (7)
        • Visual Studio (1)
      • Web & Android (121)
        • SpringBoot (37)
        • Three.js (2)
        • Spring Data JPA (9)
        • 스프링 부트 쇼핑몰 프로젝트 with JPA (25)
        • Thymeleaf (4)
        • Spring Security (15)
        • Flutter (29)
      • Programming Language (61)
        • JAVA (27)
        • JavaScript (14)
        • Dart (2)
        • Python (15)
        • PHP (3)
      • Database (43)
        • PostgreSQL (32)
        • MYSQL (7)
        • Oracle (3)
        • MSSQL (1)
      • SERVER (17)
        • TCP_IP (3)
        • 리눅스 (7)
        • AWS (7)
      • Coding Test (410)
        • 백준[JAVA] (76)
        • 프로그래머스[JAVA] (257)
        • 알고리즘 고득점 Kit[JAVA] (3)
        • SQL 고득점 Kit[ORACLE] (74)
      • CS 지식 (49)
        • [자료구조] (14)
        • [네트워크] (12)
        • [데이터베이스] (10)
        • [알고리즘] (9)
        • [운영체제] (4)
      • 기타 (6)
      • 자격증 & 공부 (62)
        • 정보처리기사 (2)
        • SQLD (6)
        • 네트워크관리사 2급 (5)
        • 리눅스마스터 1급 (44)
        • 리눅스마스터 2급 (1)
        • ISTQB (3)
        • 시스템보안 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 인기 글

  • 태그

    리눅스
    스프링
    플러터
    postgresql
    CS지식
    데이터베이스
    programmers
    pcce 기출문제
    Flutter
    springboot
    spring
    Spring Security
    백준
    CS
    DB
    스프링부트
    프로그래머스
    데이터
    Oracle
    리눅스마스터 1급
    리눅스마스터
    backjoon
    Linux
    Java
    자바
    JPA
    스프링 부트 쇼핑몰 프로젝트 with JPA
    시큐리티
    baekjoon
    python
  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[Spring Security] OAuth 2.0을 이용한 인증

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.