Google 로그인 설정
설치 단계와 이 플러그인의 전체 마크다운 가이드를 포함한 설정 지시를 복사하세요.
소개
소개Capgo Social Login을 설정하는 방법을 배울 것입니다. Google Login을 설정하려면 다음이 필요합니다:
- Google 계정
일반 설정
설명이 단계는 사용할 플랫폼에 관계없이 필수입니다.
- 이 부분에서 Google이 표시하는 로그인 화면을 설정하겠습니다. __CAPGO_KEEP_0__
- 프로젝트 선택기 클릭
- 프로젝트가 이미 없다면, 새로운 프로젝트 만들기.
- 클릭
New project
- 프로젝트 이름을 입력하고 클릭
Create
- 올바른 프로젝트가 선택되었는지 확인
- 클릭
- 설정 시작
OAuth consent screen-
__CAPGO_KEEP_0__을 클릭하세요.
-
__CAPGO_KEEP_1__을 입력하세요.
OAuth consent screen__CAPGO_KEEP_2__을 클릭하세요.
-
동의 화면 구성
OAuth 동의 화면 유형 선택 창에 External 및 Internal 옵션을 보여줍니다.
create
-
- 앱 정보를 입력하세요
-
앱 정보를 입력하기 시작하세요
App Information
- 앱 이름과 사용자 지원 이메일을 입력하세요
App Name - 사용자 지원 이메일을 입력하세요
user support email
-
당신은 CAN 앱 로고를 추가할 수 있습니다.
-
당신은 SHOULD 인증된 도메인 필드가 있는 앱 도메인 구성 섹션을 구성해야 합니다.
App domain
-
개발자 연락처 정보 섹션에 이메일 필드 아래 폼의 "저장하고 계속" 버튼을 클릭하세요. 권한 범위 구성
-
You HAVE TO provide the developer’s email
save and continue
- 앱 이름과 사용자 지원 이메일을 입력하세요
-
- Click on Save and Continue button at bottom of form
-
Configure the scopes
add or remove scopes
-
다음 범위를 선택하고 클릭하세요.
update
-
클릭
save and continue
-
- 테스트 사용자 추가
- 클릭하여
add users
- Google 이메일을 입력하고 Enter를 클릭한 후 클릭
add
- 클릭
save and continue
- 클릭하여
- 클릭
back to dashboard
- 앱을 인증하기 위해 제출하세요
온라인 접근과 오프라인 접근의 차이점
온라인 접근과 오프라인 접근의 차이점Google 로그인과 Capacitor을 사용하는 방법은 여러 가지입니다. 두 가지의 차이점을 비교한 표를 아래에示합니다.
| 온라인 접근 | 오프라인 접근 | |
|---|---|---|
| 백엔드가 필요합니다 | ❌ | ✅ |
| 장기 유지 액세스 토큰 | ❌ | ✅ |
| 쉬운 설정 | ✅ | ❌ |
액세스하고
-
리프레시 토큰을
그리고
-
백엔드에서
리프레시하는 것을 위해 __CAPGO_KEEP_0__을 교환해야 합니다.
-
앱이 백엔드에서 구글 API를 호출할 것입니다. 그러나 사용자가 앱을 적극적으로 사용할 때만.
이 경우 온라인 접근을 선택하세요.
-
앱은 사용자의 캘린더를 정기적으로 확인할 것입니다. 사용자가 앱을 적극적으로 사용하지 않을 때도.
이 경우 오프라인 접근을 선택하세요.
온라인 접근을 위한 예제 백엔드
온라인 접근을 위한 예제 백엔드이 부분의 튜토리얼에서, 사용자 인증을 백엔드에서 어떻게 하는지 보여드리겠습니다.
이 예제는 매우 간단하고, 다음 기술을 기반으로 하겠습니다:
이 예제의 code를 찾을 수 있습니다. 여기
보시다 보니:
아이디어는 매우 간단합니다. 단순한 요청을 보내고, 이 요청은 토큰이 유효한지 여부를 반환하고, 유효한 경우 사용자의 이메일과 사용자 토큰에 대한 기타 정보를 제공합니다. GET Google OAuth Playground에서 토큰 정보 응답을 보여주며 사용자 세부 정보를 제공합니다. https://www.googleapis.com/oauth2/v3/tokeninfo 그곳에서, 사용자에게 자체 JWT를 발급하거나 세션 쿠키를 발급할 수 있습니다. 최종 인증 구현의 가능성은 끝이 없습니다.
Google의 OAuth 2.0 Playground
If you do want to call Google API’s, I would strongly recommend looking at 자체 백엔드와 함께 오프라인 접근을 사용합니다.__CAPGO_KEEP_0__
__CAPGO_KEEP_1__
Section titled “Capgo를 사용하여 자체 백엔드와 함께 오프라인 접근 사용하기”오프라인 접근을 사용하려면 다음이 필요합니다:
- HTTP 서버
이 예시에서 오프라인 접근을 제공하기 위해 사용하는 기술은 다음과 같습니다:
-
LowDb 간단한 데이터베이스
이 예시의 code는 여기서 찾을 수 있습니다 여기
클라이언트 code은 다음과 같습니다:
import { Capacitor } from '@capacitor/core';import { GoogleLoginOfflineResponse, SocialLogin } from '@capgo/capacitor-social-login';import { usePopoutStore } from '@/popoutStore'; // <-- specific to my app
const baseURL = "[redacted]";
async function fullLogin() { await SocialLogin.initialize({ google: { webClientId: '[redacted]', iOSClientId: '[redacted]', iOSServerClientId: 'The same value as webClientId', mode: 'offline' // <-- important } }) const response = await SocialLogin.login({ provider: 'google', options: { forceRefreshToken: true // <-- important } })
if (response.provider === 'google') { const result = response.result as GoogleLoginOfflineResponse const res = await fetch(`${baseURL}/auth/google_offline`, { headers: { "Content-Type": "application/json" }, body: JSON.stringify({ serverAuthCode: result.serverAuthCode, platform: Capacitor.getPlatform() }), method: "POST" })
if (res.status !== 200) { popoutStore.popout("Full google login failed", "check console"); return }
const { jwt } = await res.json(); const userinfo = await fetch(`${baseURL}/auth/get_google_user`, { headers: { Authorization: `Bearer ${jwt}` } }) if (userinfo.status !== 200) { popoutStore.popout("Full google (userinfo) login failed", "check console"); return } popoutStore.popout("userinfo res", await userinfo.text()); }}주의하십시오. 이 앱에는 호출이 없습니다. 이는 Google 오프라인 모드에서 refresh가 백엔드가 리프레시 토큰을 안전하게 저장한 후에 발생하기 때문입니다. SocialLogin.refresh() 페이지 편집 serverAuthCode 이전