๐Ÿš€
Growth log
  • About me
  • I LEARNED
    • General
      • ๊ฐœ๋ฐœ์ž ๊ฟ€ํŒ
      • ๊ทธ๋กœ์Šคํ•ดํ‚น ๊ธฐ์ดˆ
      • ๊ฐœ๋ฐœ์ž์—๊ฒŒ ๋„๋ฉ”์ธ ์ง€์‹์€ ์–ผ๋งˆ๋‚˜ ์ค‘์š”ํ• ๊นŒ?
      • DTO ๋…ผ์Ÿ์— ๋Œ€ํ•˜์—ฌ
      • MSA๋ž€?
    • Seminar
      • ํ…Œ์ŠคํŠธ ์ปค๋ฒ„๋ฆฌ์ง€ 100% - SLASH 21
      • TDD๊ฐ€ ์‹คํŒจํ•˜๋Š” ์ด์œ  - by ์ด๊ทœ์›๋‹˜
      • ๋Œ€๊ทœ๋ชจ ํŠธ๋ž˜ํ”ฝ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ์„ฑ๋Šฅ ํŠœ๋‹ ๋…ธํ•˜์šฐ ๋‹ค ์•Œ๋ ค ๋“œ๋ฆผ|๋ผ์ธ๊ฐœ๋ฐœ์‹ค๋ก
      • ๊ฒฐ์ œ ์‹œ์Šคํ…œ์˜ SDK์™€ API ๋””์ž์ธ - SLASH 21
    • Web
      • SOP์™€ CORS
    • Spring & OOP
      • DTO vs VO
    • Ruby On Rails
      • Rails lib ๋””๋ ‰ํ† ๋ฆฌ์— ๋Œ€ํ•˜์—ฌ
      • Rails์˜ concerns๋ž€?
      • Rails์—์„œ์˜ GC ์ž‘๋™์›๋ฆฌ
      • Eager loading vs Lazy loading
      • Rails ํ™˜๊ฒฝ ๊ตฌ์„ฑ
      • ActionCable
      • ๐Ÿ“”Perfect ruby on rails
        • MVC ํŒจํ„ด์ธ Rails
        • Ruby on Rails ๊ธฐ๋ณธ - ์ปจํŠธ๋กค๋Ÿฌ
        • Ruby on Rails ๊ธฐ๋ณธ - ๋ทฐ
        • Ruby on Rails ๊ธฐ๋ณธ - ๋ชจ๋ธ
        • ์Šค์บํด๋”ฉ ๊ธฐ๋Šฅ์„ ์‚ฌ์šฉํ•œ Rails ๊ฐœ๋ฐœ ๊ธฐ์ดˆ
        • ๋ทฐ ๊ฐœ๋ฐœ
        • ๋ชจ๋ธ ๊ฐœ๋ฐœ
        • ๋ชจ๋ธ ๊ฐœ๋ฐœ - ๋‚™๊ด€์  ๋™์‹œ ์‹คํ–‰ ์ œ์–ด
        • ๋ชจ๋ธ ๊ฐœ๋ฐœ - ์œ ํšจ์„ฑ ๊ฒ€์‚ฌ ๊ตฌํ˜„
        • ๋ชจ๋ธ ๊ฐœ๋ฐœ - Association
        • ๋ชจ๋ธ ๊ฐœ๋ฐœ - ์ฝœ๋ฐฑ
        • ๋ชจ๋ธ ๊ฐœ๋ฐœ - ๋งˆ์ด๊ทธ๋ ˆ์ด์…˜
        • ๋ชจ๋ธ ๊ฐœ๋ฐœ - ๋ฐ์ดํ„ฐ ์ดˆ๊ธฐํ™”
        • ์ปจํŠธ๋กค๋Ÿฌ ๊ฐœ๋ฐœ - ์š”์ฒญ ์ •๋ณด ์ถ”์ถœ
        • ์ปจํŠธ๋กค๋Ÿฌ ๊ฐœ๋ฐœ - ์‘๋‹ต
        • ์ปจํŠธ๋กค๋Ÿฌ ๊ฐœ๋ฐœ - ์ƒํƒœ ๊ด€๋ฆฌ
        • ๋ผ์šฐํŒ… - RESTful
        • ๋ผ์šฐํŒ… - RESTful ์ธํ„ฐํŽ˜์ด์Šค์˜ ์‚ฌ์šฉ์ž ์ •์˜ํ™”
        • ๋ผ์šฐํŒ… - RESTful ํ•˜์ง€ ์•Š์€ ๋ผ์šฐํŠธ ์ •์˜
        • ํ…Œ์ŠคํŠธ
        • ํ…Œ์ŠคํŠธ - ์ค€๋น„
        • ํ…Œ์ŠคํŠธ - Unit ํ…Œ์ŠคํŠธ
        • ํ…Œ์ŠคํŠธ - Functional ํ…Œ์ŠคํŠธ
        • ํ…Œ์ŠคํŠธ - Integration ํ…Œ์ŠคํŠธ
        • ํด๋ผ์ด์–ธํŠธ ๊ฐœ๋ฐœ - Sprockets vs Webpacker
        • ํด๋ผ์ด์–ธํŠธ ๊ฐœ๋ฐœ - Sprockets
    • Node.js & Express
      • ๊ธฐ๋ณธ ๊ฐœ๋…
      • npx
    • Programing Language
      • Java
        • JavaDoc์— ๋Œ€ํ•ด
        • invocation์— ๋Œ€ํ•ด์„œ
        • ์–ด๋…ธํ…Œ์ด์…˜
        • ์ถ”์ƒํด๋ž˜์Šค & ์ธํ„ฐํŽ˜์ด์Šค
        • Package
        • ์˜ค๋ฒ„๋กœ๋”ฉ vs ์˜ค๋ฒ„๋ผ์ด๋”ฉ
      • Javascript
        • TCP School ํ›‘์–ด๋ณด๊ธฐ
          • ํƒ€์ž…
          • ํ˜• ๋ณ€ํ™˜
          • ๋ณ€์ˆ˜
          • ์—ฐ์‚ฐ์ž
          • ๋ฐ˜๋ณต๋ฌธ
          • ๋ฐฐ์—ด(array)
          • ํ•จ์ˆ˜
          • ํ•จ์ˆ˜ - ์Šค์ฝ”ํ”„์™€ ํ˜ธ์ด์ŠคํŒ…
          • ํ•จ์ˆ˜ - ๋งค๊ฐœ๋ณ€์ˆ˜์™€ ์ธ์ˆ˜
          • ํ•จ์ˆ˜ - ๋ฏธ๋ฆฌ ์ •์˜๋œ ์ „์—ญ ํ•จ์ˆ˜
          • ๊ฐ์ฒด
          • ํ”„๋กœํ† ํƒ€์ž…
          • DOM
          • BOM - Window ๊ฐ์ฒด
          • ์ด๋ฒคํŠธ(event)
      • Ruby
        • ๐Ÿ“”ํผํŽ™ํŠธ ๋ฃจ๋น„
    • DB
      • Redis
        • Redis ๊ฐœ์š”
      • Index(์ธ๋ฑ์Šค)?
      • DB Transaction & Lock
      • ๋™์‹œ์„ฑ ์ œ์–ด์— ๊ด€ํ•˜์—ฌ
      • Lock(์ž ๊ธˆ)์ด๋ž€?
      • ActiveRecord lock vs with_lock
      • Table lock vs Row lock
      • WHERE 1=1 ๊ตฌ๋ฌธ์— ๋Œ€ํ•˜์—ฌ
      • COUNT(*) vs COUNT(indexed column)
      • ๐Ÿ“•๊ด€๊ณ„ํ˜• ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ์‹ค์ „์ž…๋ฌธ
      • ๐Ÿ“”SQL ์ฒซ๊ฑธ์Œ
      • ๐Ÿ“”๋ชจ๋‘์˜ SQL
    • Design Patterns
      • Observer pattern
      • Flyweight pattern
      • Singleton pattern
    • OOP
      • ๐Ÿ“”์˜ค๋ธŒ์ ํŠธ
        • 6์žฅ ๋ฉ”์‹œ์ง€์™€ ์ธํ„ฐํŽ˜์ด์Šค
      • ํด๋ž˜์Šค๊ฐ„ ๊ด€๊ณ„ ๊ฐ„๋‹จ ์ •๋ฆฌ
    • Regex
    • Collaboration
      • Git
      • Sourcetree
  • DAILY REVIEW
    • 2021
      • August
        • 2021-08-25(Wed)
        • 2021-08-23(Mon)
        • 2021-08-11(Wed)
        • 2021-08-04(Wed)
        • 2021-08-03(Tue)
        • 2021-08-02(Mon)
      • July
        • 2021-07-29(Thu)
        • 2021-07-26(Mon)
        • 2021-07-23(Fri)
        • 2021-07-22(Thu)
        • 2021-07-21(Wed)
        • 2021-07-20(Tue)
        • 2021-07-19(Mon)
        • 2021-07-15(Thu)
        • 2021-07-14(Wed)
        • 2021-07-13(Tue)
        • 2021-07-12(Mon)
      • June
        • 2021-06-05(Sat)
        • 2021-06-04(Fri)
        • 2021-06-03(Thu)
        • 2021-06-02(Wed)
        • 2021-06-01(Tue)
      • May
        • 2021-05-31(Mon)
        • 2021-05-29(Sat)
        • 2021-05-28(Fri)
        • 2021-05-27(Thu)
        • 2021-05-26(Wed)
        • 2021-05-25(Tue)
        • 2021-05-24(Mon)
        • 2021-05-22(Sat)
        • 2021-05-21(Fri)
        • 2021-05-20(Thu)
        • 2021-05-19(Wed)
        • 2021-05-18(Tue)
        • 2021-05-17(Mon)
        • 2021-05-15(Sat)
        • 2021-05-13(Thu)
        • 2021-05-12(Wed)
        • 2021-05-11(Tue)
        • 2021-05-10(Mon)
        • 2021-05-03(Mon)
      • April
        • 2021-04-30(Fri)
        • 2021-04-29(Thu)
        • 2021-04-28(Wed)
        • 2021-04-27(Tue)
        • 2021-04-26(Mon)
        • 2021-04-24(Sat)
        • 2021-04-23(Fri)
        • 2021-04-21(Wed)
        • 2021-04-20(Tue)
        • 2021-04-19(Mon)
        • 2021-04-18(Sun)
        • 2021-04-16(Fri)
        • 2021-04-15(Thu)
        • 2021-04-14(Wed)
        • 2021-04-12(Mon)
        • 2021-04-11(Sun)
        • 2021-04-09(Fri)
        • 2021-04-08(Thu)
        • 2021-04-06(Tue)
        • 2021-04-05(Mon)
        • 2021-04-04(Sun)
        • 2021-04-03(Sat)
        • 2021-04-02(Fri)
        • 2021-04-01(Thu)
      • March
        • 2021-03-29(Mon)
        • 2021-03-28(Sun)
        • 2021-03-26(Fri)
        • 2021-03-25(Thu)
        • 2021-03-24(Wed)
        • 2021-03-23(Tue)
        • 2021-03-22(Mon)
        • 2021-03-21(Sun)
        • 2021-03-20(Sat)
        • 2021-03-17(Wed)
        • 2021-03-16(Tue)
        • 2021-03-15(Mon)
        • 2021-03-12(Fri)
        • 2021-03-11(Thu)
        • 2021-03-10(Wed)
        • 2021-03-09(Tue)
        • 2021-03-08(Mon)
        • 2021-03-07(Sun)
        • 2021-03-05(Fri)
        • 2021-03-03(Wed)
        • 2021-03-02(Tue)
        • 2021-03-01(Mon)
      • Feb
        • 2021-02-26(Fri)
        • 2021-02-25(Thu)
        • 2021-02-24(Wed)
        • 2021-02-23(Tue)
        • 2021-02-22(Mon)
        • 2021-02-19(Fri)
        • 2021-02-18(Thu)
        • 2021-02-17(Wed)
        • 2021-02-16(Tue)
        • 2021-02-15(Mon)
        • 2021-02-14(Sun)
        • 2021-02-13(Sat)
        • 2021-02-12(Fri)
        • 2021-02-10(Wed)
        • 2021-02-09(Tue)
        • 2021-02-08(Mon)
        • 2021-02-07(Sun)
        • 2021-02-05(Fri)
        • 2021-02-03(Wed)
        • 2021-02-02(Tue)
        • 2021-02-01(Mon)
      • Jan
        • 2021-01-29(Fri)
        • 2021-01-28(Thu)
        • 2021-01-27(Wed)
        • 2021-01-26(Tue)
        • 2021-01-25(Mon)
        • 2021-01-23(Sat)
        • 2021-01-22(Fri)
        • 2021-01-20(Wed)
        • 2021-01-19(Tue)
        • 2021-01-18(Mon)
        • 2021-01-12(Tue)
        • 2020-01-11(Mon)
        • 2021-01-08(Fri)
        • 2021-01-07(Thu)
        • 2021-01-06(Wed)
        • 2021-01-05(Tue)
        • 2021-01-04(Mon)
        • 2021-01-01(Fri)
    • 2020
      • Dec
        • 2020-12-30(Thu)
        • 2020-12-25(Fri)
        • 2020-12-24(Thu)
        • 2020-12-23(Wed)
        • 2020-12-22(Tue)
        • 2020-12-21(Mon)
        • 2020-12-18 (Fri)
      • Nov
        • 2020-11-30(Mon)
        • 2020-11-28(Sat)
        • 2020-11-26(Thu)
        • 2020-11-25(Wed)
        • 2020-11-24(Tue)
        • 2020-11-23(Mon)
        • 2020-11-22(Sun)
        • 2020-11-20(Fri)
        • 2020-11-19(Thu)
        • 2020-11-18(Wed)
        • 2020-11-17(Tue)
        • 2020-11-14(Sat)
        • 2020-11-13(Fri)
        • 2020-11-12(Thu)
        • 2020-11-11(Wed)
        • 2020-11-09(Mon)
        • 2020-11-07(Sat)
        • 2020-11-05(Thu)
        • 2020-11-04(Wed)
        • 2020-11-03(Tue)
        • 2020-11-02(Mon)
    • Good article ์•„์นด์ด๋น™
Powered by GitBook
On this page
  • ์ƒ์„ธ ํ•™์Šต ๋‚ด์šฉ
  • OAuth2
  • OAuth ์ธ์ฆ์„ ์œ„ํ•ด ํ•„์š”ํ•œ ๊ฐ์ฒด
  • OAuth ๋กœ๊ทธ์ธ์„ ์œ„ํ•ด ํ•„์š”ํ•œ ์š”์†Œ
  • OAuth ์ธ์ฆ ๊ณผ์ •
  • ์ฐธ๊ณ 
  • ํ•™์Šต ๋‚ด์šฉ์— ๋Œ€ํ•œ ๊ฐœ์ธ์ ์ธ ์ดํ‰
  • ๋‹ค์Œ ํ•™์Šต ๊ณ„ํš

Was this helpful?

  1. DAILY REVIEW
  2. 2021
  3. March

2021-03-15(Mon)

ํ•ญ๋ชฉ

๋‚ด์šฉ

ํ•™์Šต ๋‚ ์งœ

2021-03-15(์›”)

ํ•™์Šต ์‹œ๊ฐ„

11:00~24:00

ํ•™์Šต ๋ฒ”์œ„ ๋ฐ ์ฃผ์ œ

OAuth

ํ•™์Šต ๋ชฉํ‘œ

ํŠธ๋ Œ์„ผ๋”์Šค ์ œ์ถœ์ „ ๋งˆ์ง€๋ง‰ ์ฒดํฌ๋ฆฌ์ŠคํŠธ๋ฅผ ๋ชจ๋‘ ํด๋ฆฌ์–ดํ•œ๋‹ค.

๋™๋ฃŒ ํ•™์Šต ๋ฐฉ๋ฒ•

eunhkim, sanam, jujeong, yohlee์™€ ํŽ˜์–ด ํ”„๋กœ๊ทธ๋ž˜๋ฐ

์ƒ์„ธ ํ•™์Šต ๋‚ด์šฉ

OAuth๋ฅผ ๋‹ค์‹œ ํ™œ์„ฑํ™”์‹œ์ผฐ๋Š”๋ฐ ์šฐ๋ฆฌ ๋ฐœ๋ชฉ์„ ์žก๋Š”๋‹ค. ๋‹ค์‹œ ๊ฐœ๋…์„ ๋˜์ƒˆ๊ฒจ๋ณด์ž.

OAuth2

์‹ค์ œ ๋น„๋ฐ€๋ฒˆํ˜ธ ๋Œ€์‹  AccessToken์ด๋ผ๋Š” ์ผ์ข…์˜ ๋น„๋ฐ€ํ‚ค๋ฅผ ์ด์šฉํ•œ๋‹ค.

  • AccessToken์˜ ์žฅ์ 

    • ์‚ฌ์šฉ์ž์˜ ์‹ค์ œ ๋น„๋ฐ€๋ฒˆํ˜ธ๊ฐ€ ์•„๋‹ˆ๋‹ค.

    • ์„œ๋น„์Šค์˜ ๋ชจ๋“  ๊ธฐ๋Šฅ์ด ์•„๋‹Œ ์ผ๋ถ€ ๊ธฐ๋Šฅ๋งŒ ์ด์šฉ ๊ฐ€๋Šฅํ•œ ํ† ํฐ์ด๋‹ค.

OAuth๋Š” ๋‹ค๋ฅธ ์„œ๋น„์Šค๋กœ๋ถ€ํ„ฐ AccessToken์„ ์–ป์–ด๋‚ด๋Š” ๊ธฐ์ˆ ์ด๋‹ค.

OAuth ์ธ์ฆ์„ ์œ„ํ•ด ํ•„์š”ํ•œ ๊ฐ์ฒด

  1. User(Resource Owner): ๋ฆฌ์†Œ์Šค์˜ ์ฃผ์ธ(์ผ๋ฐ˜ ์‚ฌ์šฉ์ž)

  2. App(client): ์ œ 3์ž ์•ฑ. User๊ฐ€ ์‚ฌ์šฉํ•˜๋Š” ์„œ๋น„์Šค

  3. Auth server / Resource server (ex. Google, 42api, github, facebook etc)

    • Resource server: ๋ฆฌ์†Œ์Šค ์ €์žฅ ์„œ๋ฒ„. API๋ฅผ ํ†ตํ•ด ๋ฆฌ์†Œ์Šค๋ฅผ ์ œ๊ณต

    • Authorization server: ์ธ์ฆ ๋‹ด๋‹น ์„œ๋ฒ„: ์ธ์ฆ์„ ์™„๋ฃŒํ•˜๋ฉด access token์„ client์—๊ฒŒ ๋ณด๋‚ธ๋‹ค.

      • ๋ฆฌ์†Œ์Šค ์„œ๋ฒ„์™€ ์ธ์ฆ ์„œ๋ฒ„๋Š” ๊ฐ™์€ ์„œ๋ฒ„์ผ ์ˆ˜๋„ ์žˆ๋‹ค.

      • ์ผ๋ฐ˜์ ์œผ๋กœ ๊ตฌ๊ธ€์ด๋‚˜ ํŽ˜์ด์Šค๋ถ ๊ฐ™์€ ๋Œ€๊ทœ๋ชจ ์„œ๋น„์Šค์—์„œ๋Š” ๋ฆฌ์†Œ์Šค ์„œ๋ฒ„์™€ ์ธ์ฆ ์„œ๋ฒ„๋ฅผ ๋ถ„๋ฆฌํ•œ๋‹ค.

OAuth ๋กœ๊ทธ์ธ์„ ์œ„ํ•ด ํ•„์š”ํ•œ ์š”์†Œ

OAuth ๋กœ๊ทธ์ธ์„ ํ•˜๊ณ ์ž ํ•˜๋Š” ์„œ๋น„์Šค์—์„œ ์•„๋ž˜ ์„ธ ๊ฐ€์ง€ ์š”์†Œ๋ฅผ ๋ฐ›์•„์•ผ ํ•œ๋‹ค.

  1. Client ID: public key ์ด๋‹ค. ๊ณต๊ฐœํ•ด๋„ ๋œ๋‹ค.

  2. Client Secret: secret key์ด๋‹ค. ๊ณต๊ฐœํ•˜๋ฉด ์•ˆ ๋œ๋‹ค. ๋ณดํ†ต ํ™˜๊ฒฝ๋ณ€์ˆ˜์— ๋‹ด์•„ ๋‘”๋‹ค.

  3. Redirect URL: Client ID์™€ Client Secret์„ ํ™•์ธํ•œ ํ›„ redirectํ•  url ์ฃผ์†Œ์ด๋‹ค.

OAuth ์ธ์ฆ ๊ณผ์ •

์ „์ œ

Client๊ฐ€ Auth Server๋กœ๋ถ€ํ„ฐ Client ID, Client Secret, Redirect URL์„ ๋ชจ๋‘ ๋“ฑ๋ก/๋ฐœ๊ธ‰ ๋ฐ›์€ ์ƒํƒœ์—ฌ์•ผ ํ•œ๋‹ค.

Resource Owner์˜ ์Šน์ธ

  • Resource Owner๊ฐ€ Auth Server์—๊ฒŒ ์Šน์ธ ์š”์ฒญ์„ ๋ณด๋‚ธ๋‹ค.

  • Auth Server๊ฐ€ Resource Owner์—๊ฒŒ Authorization Code๋ฅผ ๋ณด๋‚ธ๋‹ค.

  • ์ด์ œ Resource Owner๊ฐ€ Client์—๊ฒŒ Authorization Code๋ฅผ ๋ณด๋‚ธ๋‹ค.

  • Client๋Š” Client ID, Client Secret, Redirect URL, Authorization Code ๋„ค ๊ฐ€์ง€๋ฅผ ๋ชจ๋‘ ๊ฐ–๊ณ  ์žˆ๋Š” ์ƒํƒœ์ด๋‹ค.

Auth Server์˜ ์Šน์ธ

  • ์œ„ ๋„ค ๊ฐ€์ง€ ์ •๋ณด๋ฅผ Auth Server์— ๋ณด๋‚ธ๋‹ค. (Redirect URL์€ optional)

    • redirect_url์„ ๋ณด๋‚ด๋Š” ๊ฑด ์„ ํƒ์ด๋‹ค.

    • ํ•˜์ง€๋งŒ Client ID, Client Secret, Authorization Code ์„ธ ๊ฐ€์ง€๋Š” ๊ผญ ๋ณด๋‚ด์•ผ ํ•œ๋‹ค.

    • Resource Server๋Š” ๋„ค ๊ฐ€์ง€ ์ •๋ณด๊ฐ€ ๋ชจ๋‘ ์ผ์น˜ํ•˜๋Š”์ง€ ํ™•์ธํ•œ๋‹ค.

    • ํ•˜๋‚˜๋ผ๋„ ๋ถˆ์ผ์น˜ ํ•  ๊ฒฝ์šฐ OAuth ๋กœ๊ทธ์ธ์€ ์‹คํŒจํ•œ๋‹ค.

    • ๋ชจ๋‘ ์ผ์น˜ํ•˜๋ฉด Access Token ์„ ๋ฐœ๊ธ‰ํ•œ๋‹ค.

      • Authorization Code ๊ฐ’์€ ๋” ์ด์ƒ ํ•„์š”์—†๊ธฐ ๋•Œ๋ฌธ์— ์‚ญ์ œํ•œ๋‹ค.

Access Token ๋ฐœ๊ธ‰

  • ๋ฐœ๊ธ‰ ๋ฐ›์€ Access Token์„ ํ†ตํ•ด์„œ Resource Server์˜ ๊ธฐ๋Šฅ์„ ์ด์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

Refresh Token

  • Access Token์€ cookie์ฒ˜๋Ÿผ ๋งŒ๋ฃŒ ๊ธฐํ•œ์ด ์žˆ๋‹ค.

  • ๋”ฐ๋ผ์„œ ๋งŒ๋ฃŒ๊ฐ€ ๋˜๋ฉด ์žฌ๋ฐœ๊ธ‰ ๋ฐ›์•„์•ผํ•œ๋‹ค.

  • ์ด ๋•Œ ์‚ฌ์šฉํ•˜๋Š” ๊ฒŒ Refresh Token ์ด๋‹ค.

  • ์„œ๋น„์Šค๋งˆ๋‹ค Refresh Token์„ ๋ฐœ๊ธ‰ํ•˜์ง€ ์•Š๋Š” ๊ฒฝ์šฐ๋„ ์žˆ๊ณ  ์“ฐ๋Š” ๋ฐฉ์‹๋„ ๋‹ค๋ฅด๋‹ค. Access Token์€ ์ฃผ๋กœ ์„ธ์…˜์— ์ €์žฅํ•œ๋‹ค.

    • ๋งŒ๋ฃŒ ๊ธฐํ•œ์ด ์งง๋‹ค.

  • Refresh Token์€ ์ค‘์š”ํ•˜๊ธฐ ๋•Œ๋ฌธ์— DB์— ์ €์žฅํ•œ๋‹ค.

    • ๋งŒ๋ฃŒ ๊ธฐํ•œ์ด ๊ธธ๋‹ค.

์šฐ๋ฆฌ ํ”„๋กœ์ ํŠธ์—์„œ๋Š” ์•„๋ž˜ ๊ด€๊ณ„์ด๋‹ค.

  • Resource owner: User

  • Resource server: 42 api server

  • Client: Rails server

์ฐธ๊ณ 

ํ•™์Šต ๋‚ด์šฉ์— ๋Œ€ํ•œ ๊ฐœ์ธ์ ์ธ ์ดํ‰

Authorization code๋Š” ์ž˜ ๋ฐ›์•˜๊ณ , 42api ์„œ๋ฒ„์— Authroization code๋ฅผ ๋ณด๋ƒˆ๋Š”๋ฐ Access Token์ด ์ œ๋Œ€๋กœ ๋Œ์•„์˜ค์ง€ ์•Š์•˜๋‹ค. ํ  ์•Œ๊ณ ๋ณด๋‹ˆ 42api ๋ฌธ์„œ์— ์ œ๋Œ€๋กœ ๋ช…์‹œ๋˜์ง€ ์•Š์€ ์ˆจ๊ฒจ์ง„ ๊ทœ์น™๋“ค์ด ์žˆ์–ด์„œ ๊ทธ๋Ÿฐ ๊ฒƒ์ด์—ˆ๋‹ค. ๊ฐ€๋ น required ๋ผ๊ณ  ์ ํ˜€์žˆ์ง€ ์•Š์€ key ๊ฐ’์ด ์‚ฌ์‹ค์€ required ๋ผ๋“ ์ง€.. api ๋ฌธ์„œ๊ฐ€ ์ œ๋Œ€๋กœ ์ ํ˜€์žˆ์ง€ ์•Š์•„์„œ ์ƒ๊ธด ๋ฌธ์ œ ๋•์— ์‹œ๊ฐ„์„ ๋งŽ์ด์ผ๋‹ค. ๋ฌธ์„œ ๊ด€๋ฆฌ์˜ ์ค‘์š”์„ฑ์„ ๊นจ๋‹ฌ์„ ์ˆ˜ ์žˆ์—ˆ๋‹ค.

๋‹ค์Œ ํ•™์Šต ๊ณ„ํš

  • ํŠธ๋ Œ์„ผ๋”์Šค ํ…Œ์ŠคํŠธ

Previous2021-03-16(Tue)Next2021-03-12(Fri)

Last updated 4 years ago

Was this helpful?

Velog ์ฐธ๊ณ 
https://ruby-doc.org/stdlib-2.7.2/libdoc/net/http/rdoc/Net/HTTP.html
https://api.intra.42.fr/apidoc/guides/web_application_flow
https://medium.com/@charmiigarg/apigee-introduction-to-oauth-2-0-grant-types-4352aa7aacf7