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

2023. 10. 19. 10:11·Web & Android/Spring Security

카카오 로그인 실습 - 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
'Web & Android/Spring Security' 카테고리의 다른 글
  • [Spring Security] Annotation
  • [Spring Security] SNS 로그인
  • [Spring Security] 카카오 로그인 실습 - Web
  • [Spring Security] Access Token+ Refresh Token을 이용한 인증
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (829)
      • 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 (445)
        • 백준[JAVA] (108)
        • 프로그래머스[JAVA] (260)
        • 알고리즘 고득점 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)
  • 블로그 메뉴

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

  • 태그

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

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

티스토리툴바