1. 개요
Firebase를 이용한 Google Login를 정리합니다.
소스 : HTML, JavaScript ES6+(IE 미지원)
기본 Spark 요금제는 일정 사용량은 무료입니다. 특히 Authentication 한국은 완전 무료입니다.
2. 내용
data:image/s3,"s3://crabby-images/09393/09393368fe1c8ec99edbdab2822049e46074d9a8" alt=""
- firebase.google.com 접속, ‘콘솔로 이동’ 클릭
data:image/s3,"s3://crabby-images/2866a/2866aaff1a4eda82d54f783fade195df797b49fa" alt=""
2. ‘프로젝트 만들기’
data:image/s3,"s3://crabby-images/3a304/3a304bf8812106647bc7cd37d09df45275ae7cbc" alt=""
3. 프로젝트 이름 입력
data:image/s3,"s3://crabby-images/e78e7/e78e7f20c2be417b5f5e3b5888d809601fb1b1ca" alt=""
4. 약관 동의 후 ‘계속
data:image/s3,"s3://crabby-images/9c3e3/9c3e32bbcb76d3d6c6bc597b841f35051bfe93b3" alt=""
5. 애널리틱스 화면 확인
data:image/s3,"s3://crabby-images/47ce8/47ce8f8367f69e5586881c4cfc452d7b9b0a52cf" alt=""
6. 애널리틱스 사용하지 않고 ‘프로젝트 만들기’
data:image/s3,"s3://crabby-images/ebf0d/ebf0db05685e3242d67b091b3a830a9dc8735bf8" alt=""
7. 프로젝트 준비가 끝나면 ‘계속
data:image/s3,"s3://crabby-images/d2e90/d2e90c8f56fae3e2e1e8651e9fa495547442167f" alt=""
8. </> 버튼 클릭
data:image/s3,"s3://crabby-images/5bf55/5bf554fac4d72c7ca97d2176257b158918697909" alt=""
9. 웹 앱에 Firebase 추가 화면 확인
data:image/s3,"s3://crabby-images/11e98/11e98dc57f86eb4f9d3b57bdf47e4647f501df3e" alt=""
10. 앱 닉네임 입력
data:image/s3,"s3://crabby-images/53608/536087256d184180e467d0b9ae5590f7b731856b" alt=""
11. ‘<script> 태그 사용’ 선택
data:image/s3,"s3://crabby-images/60893/6089328d42a60eaf5150c393790d0688bb798249" alt=""
12. ‘다음’
data:image/s3,"s3://crabby-images/724ee/724ee5bdf8cf920f83df1c0c3aa95935a49b65e8" alt=""
13. ‘다음’
data:image/s3,"s3://crabby-images/54fd1/54fd13f063457386a22ed313160af9f6eb904e0b" alt=""
14. ‘콘솔로 이동’
data:image/s3,"s3://crabby-images/30d63/30d63d364e88f471fb66a26d20b142f1fdf281e1" alt=""
15. ‘앱 1개’
data:image/s3,"s3://crabby-images/f605b/f605baf73896d94ab819aed3516a7d25e9fea800" alt=""
16. Authentication 화면에서 ‘시작하기’
data:image/s3,"s3://crabby-images/6e063/6e06323d54a7367962c7d475648e1f32e1417778" alt=""
17. Sign-in method 탭에서 ‘Google’ 선택
data:image/s3,"s3://crabby-images/8aab6/8aab6ddad418cd2dbdb10008db09666152cba352" alt=""
18. ‘사용 설정’
data:image/s3,"s3://crabby-images/77e90/77e90b9f306932dc7affb24cf8d642205c74d3dd" alt=""
19. ‘프로젝트의 공개용 이름’ 및 ‘프로젝트 지원 이메일’ 선택, 확인 그리고 ‘저장’
data:image/s3,"s3://crabby-images/1334a/1334ad736f063baddfcf22780aaffd86dac24783" alt=""
20. ‘Google’ 상태 확인 및 ‘localhost’ 도메인 확인
data:image/s3,"s3://crabby-images/25e15/25e1563408ce9128b3ee7474d9b5d710670c737b" alt=""
21. ‘프로젝트 설정’
data:image/s3,"s3://crabby-images/5ef24/5ef241ca8c509965909a3091cbe38fd912d4c9ba" alt=""
22. 해당 내용 참고. 실제 소스와 다르면 에러 발생.
data:image/s3,"s3://crabby-images/8ef37/8ef379ea61af09c49baaf48d65679f79096b1963" alt=""
23. vscode에서 ‘Preview on Web Server’ Extension 설치. ‘Launch on browser’ 단축키 확인.
data:image/s3,"s3://crabby-images/53f66/53f6671260cac732071770026b6ec8f5bdbf8d06" alt=""
24. 소스 확인 후 단축키(ctrl+shift+l)로 Preview on Web Server 실행
3. 최종 소스
github : https://github.com/KimYunBeom/kdb/tree/main/firebase-google-login
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Firebase Google Login</title>
<style>
.hide {
display: none;
}
</style>
</head>
<body>
<div>
<a href="#">
<img src="./btn_google_signin_dark_normal_web.png" alt="구글 이미지" id="googleLoginButton" />
</a>
</div>
<div>
<button type="button" id="googleLogoutButton" class="hide">로그아웃</button>
</div>
<hr />
<div id="result" class="hide">
<div><span>uid : </span><span id="resultUid"></span></div>
<div><span>email : </span><span id="resultEmail"></span></div>
<div><span>name : </span><span id="resultName"></span></div>
<div>
<div>photo :</div>
<img id="resultPhoto" src="http://picsum.photos/96" alt="랜덤 이미지" />
</div>
<div><span>created : </span><span id="resultCreated"></span></div>
<div><span>last login : </span><span id="resultLastLogin"></span></div>
</div>
<script type="module">
// Import the functions you need from the SDKs you need
import { initializeApp } from 'https://www.gstatic.com/firebasejs/9.8.1/firebase-app.js';
import {
GoogleAuthProvider,
getAuth,
signInWithPopup,
signOut,
setPersistence,
} from 'https://www.gstatic.com/firebasejs/9.8.1/firebase-auth.js';
// TODO: Add SDKs for Firebase products that you want to use
// https://firebase.google.com/docs/web/setup#available-libraries
// Your web app's Firebase configuration
const firebaseConfig = {
apiKey: 'YOUR_INFORMATION',
authDomain: 'YOUR_INFORMATION',
projectId: 'YOUR_INFORMATION',
storageBucket: 'YOUR_INFORMATION',
messagingSenderId: 'YOUR_INFORMATION',
appId: 'YOUR_INFORMATION',
measurementId: 'YOUR_INFORMATION',
};
// Initialize Firebase
const app = initializeApp(firebaseConfig);
const provider = new GoogleAuthProvider();
const auth = getAuth();
const requestLogin = () => {
signInWithPopup(auth, provider)
.then((result) => {
// This gives you a Google Access Token. You can use it to access the Google API.
const credential = GoogleAuthProvider.credentialFromResult(result);
const token = credential.accessToken;
// The signed-in user info.
const user = result.user;
console.log('user :\n', JSON.stringify(user, null, 2));
const {
uid,
email,
displayName,
photoURL,
metadata: { creationTime },
metadata: { lastSignInTime },
} = user; // Destructuring Assignment. Object and nested object.
document.querySelector('#resultUid').textContent = uid;
document.querySelector('#resultEmail').textContent = email;
document.querySelector('#resultName').textContent = displayName;
document.querySelector('#resultPhoto').setAttribute('src', photoURL);
document.querySelector('#resultCreated').textContent = creationTime;
document.querySelector('#resultLastLogin').textContent = lastSignInTime;
document.querySelector('#result').classList.remove('hide');
document.querySelector('#googleLogoutButton').classList.remove('hide');
})
.catch((error) => {
// Handle Errors here.
const errorCode = error.code;
const errorMessage = error.message;
// The email of the user's account used.
const email = error.email;
// The AuthCredential type that was used.
const credential = GoogleAuthProvider.credentialFromError(error);
console.log(errorCode, errorMessage);
});
};
const requestLogout = () => {
signOut(auth)
.then(() => {
window.location.assign('https://accounts.google.com/logout');
})
.catch((error) => {
alert('로그아웃에 실패했습니다.');
});
};
const initElemEvent = () => {
googleLoginButton.addEventListener('click', () => {
requestLogin();
});
googleLogoutButton.addEventListener('click', () => {
requestLogout();
});
};
const init = () => {
initElemEvent(); // 초기화 : Element 이벤트
};
init();
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/6bc86/6bc868c6b3dfadada73f31f92b89b966c8b40964" alt=""
25. 실행된 화면 확인, 이미지 버튼 클릭
data:image/s3,"s3://crabby-images/11631/1163111b426092bbeaa8b1a77a652c22dc3dea19" alt=""
26. 이미 로그인 된 경우, 팝업에서 추가 인증 없이 바로 브라우저에서 로그인 결과 출력. ‘로그아웃’
data:image/s3,"s3://crabby-images/221b0/221b0a60c47fa7566c98bd4422d2058c253c8ef9" alt=""
27. 로그아웃 화면, 크롬 웹 브라우저의 프로필도 동시에 일시중지됨
data:image/s3,"s3://crabby-images/1272a/1272af22c4e50b0dea09bd1aeee8013b425ab0e2" alt=""
28. FireFox 웹 브라우저에서 테스트 화면 다시 접근. 로그아웃 확인
data:image/s3,"s3://crabby-images/f43a6/f43a6d546cca52caddc735d7c0df82f20b835453" alt=""
29. 로그인 시도, 이메일과 비밀번호를 입력하여 다시 진행
data:image/s3,"s3://crabby-images/5dce9/5dce9090d93808f07750946ee680d06a3d5d66cb" alt=""
30. 로그인 확인. ‘로그아웃’
data:image/s3,"s3://crabby-images/8615e/8615eadb43c29cc4ce5821487cdb59a569112664" alt=""
31. 크롬과 다른 로그아웃 화면 확인
4. 참고URL
- 구글 로그인 브랜드 가이드라인
https://developers.google.com/identity/branding-guidelines?hl=ko
- Firebase Web 가이드
https://firebase.google.com/docs/web/setup?hl=ko
- Firebase Web Sign Out 가이드
https://firebase.google.com/docs/auth/web/password-auth?hl=ko
감사합니다 🙂