Firebase-Facebook 인증

이 장에서는 Firebase Facebook 인증으로 사용자를 인증합니다.

1 단계-Facebook 인증 활성화

Firebase 대시 보드를 열고 Auth사이드 메뉴에서. 다음으로 우리는SIGN-IN-METHOD탭 바에서. Facebook 인증을 활성화하고 추가해야하므로 열어 둡니다.App IDApp Secret 2 단계를 마치면

2 단계-Facebook 앱 만들기

Facebook 인증을 활성화하려면 Facebook 앱을 만들어야합니다. 시작 하려면 이 링크 를 클릭하십시오 . 앱이 생성되면 복사해야합니다.App IDApp Secret 1 단계에서 열어 둔 Firebase 페이지로 이동합니다. OAuth Redirect URI이 창에서 Facebook 앱으로. 찾을 수 있습니다+ Add Product Facebook 앱 대시 보드의 사이드 메뉴 내부.

고르다 Facebook Login사이드 메뉴에 나타납니다. 입력 필드를 찾을 수 있습니다Valid OAuth redirect URIs 복사해야 할 곳 OAuth Redirect URI Firebase에서.

3 단계-Facebook SDK에 연결

시작 부분에 다음 코드를 복사하십시오. body 태그 index.html. 교체하십시오'APP_ID' Facebook 대시 보드에서 앱 ID로

다음 예를 살펴 보겠습니다.

<script>
   window.fbAsyncInit = function() {
      FB.init ({
         appId      : 'APP_ID',
         xfbml      : true,
         version    : 'v2.6'
      });
   };

   (function(d, s, id) {
      var js, fjs = d.getElementsByTagName(s)[0];
      if (d.getElementById(id)) {return;}
      js = d.createElement(s); js.id = id;
      js.src = "//connect.facebook.net/en_US/sdk.js";
      fjs.parentNode.insertBefore(js, fjs);
   } (document, 'script', 'facebook-jssdk'));
	
</script>

4 단계-버튼 만들기

처음 세 단계에서 모든 것을 설정 했으므로 이제 로그인 및 로그 아웃을위한 두 개의 버튼을 만들 수 있습니다.

index.html

<button onclick = "facebookSignin()">Facebook Signin</button>
<button onclick = "facebookSignout()">Facebook Signout</button>

5 단계-인증 기능 생성

이것이 마지막 단계입니다. 열다index.js 다음 코드를 복사하십시오.

index.js

var provider = new firebase.auth.FacebookAuthProvider();

function facebookSignin() {
   firebase.auth().signInWithPopup(provider)
   
   .then(function(result) {
      var token = result.credential.accessToken;
      var user = result.user;
		
      console.log(token)
      console.log(user)
   }).catch(function(error) {
      console.log(error.code);
      console.log(error.message);
   });
}

function facebookSignout() {
   firebase.auth().signOut()
   
   .then(function() {
      console.log('Signout successful!')
   }, function(error) {
      console.log('Signout failed')
   });
}