코딩코딩/웹개발
[기록용] 카카오 소셜 로그인
g0n1
2023. 6. 4. 23:39
728x90
카카오 소셜로그인
간단한 흐름
오늘 제가 직접 연동해보니 이런 순서더라구요. 각 단계별로 예제코드와 함께 살펴보겠습니다.
(저는 javascript SDK 말고 REST API 방식으로 했으니 SDK 원하시는 분들은 다른 곳 ㄱㄱ)
1. 프론트가 카카오한테 인가코드 받아오기
- 카카오 로그인 하려면 카카오 개발자 계정에 있는 앱 중에 어떤 앱이고, 로그인하면 어디로 리다이렉트 받을지 써놔야함.
- 유저가 a태그를 누르고 저 url로 이동하면 익숙한 카카오 로그인 화면이 뜬다.
- 로그인하면 리다이렉트 주소로 보내주는데, 이때 url에 query string으로 code를 껴준다.
- 이 code가 바로 인가코드다.
const KAKAO_URL = `https://kauth.kakao.com/oauth/authorize?response_type=code&client_id=${REST_API_KEY}&redirect_uri=${REDIRECT_URI}`;
const KakaoLogin = () => {
return <a href={KAKAO_URL}>{"ASDS"}</a>;
};
2. 프론트가 백엔드로 인가코드 보내주기
- 나는 리다이렉트 페이지에 useEffect를 설정해놓았는데 다음과 같다.
- window에서 현재 url 읽어다가 code(인가코드)만 분리함
- 분리한 코드를 가지고 백엔드에 요청 보냄.
- 이제 우리 백엔드 서버에서 잘 처리해서 응답이 오길 기다리면 되겠죠?
3. 백엔드가 카카오한테 토큰 받아오기
- 백엔드가 받은 request에는 2-1-ii에서 프론트가 보낸 인가코드가 있을 겁니다.
- 이걸 다시 카카오로 보내면 카카오에서 액세스토큰, 리프레시 토큰 등등 줌
- 카카오에서 준 토큰이 생겼다!
4. 백엔드가 프론트한테 최종적으로 토큰 보내주기
- 위에서 받은 토큰 + (optional) 그외 부가 정보를 프론트로 내려줍니다.
- 그럼 2-2에서 기다리고 있던 프론트가 토큰을 받고 로그인에 성공한 것입니다.
혹시나 싶어 테스트용으로 대충 만든 서버 코드 공유
const express = require('express')
const http = require('http')
const request = require('request')
const app = express()
const port = 5000
app.get('/oauth/kakao', (req, res) = {
const code = req.query.code;
const host = `https://kauth.kakao.com/oauth/token?code=${code}`
request.post({
qs: {
grant_type:'authorization_code', // 고정임
client_id: 님들 코드,
redirect_uri: 님들이 쓴 redirect_uri,
code
},
headers: {
'Content-type': 'application/x-www-form-urlencoded;charset=utf-8',
},
url: host,
method:'POST',
}, function(err,response,body){
const {
access_token,
expires_in,
refresh_token,
refresh_token_expires_in,
token_type,
scope
} = body
// db 저장 기타 등등
res.send({토큰을 보낸다던가~})
})
})
app.listen(port, () => {
console.log(`Example app listening on port ${port}`)
})
728x90