@react-native-seoul/kakao-login v2.0.0
@react-native-seoul/kakao-login
React Native 카카오 로그인 라이브러리 입니다. @react-native-seoul/kakao-login < 3.0 이하 버전을 쓰시는 분들은 DEPRECATED README를 참고해주세요.
세부 예제는 KakaoLoginExample 폴더 안의 예제 프로젝트를 확인해주세요.
해당 라이브러리는 flow와 typescript를 지원합니다.
Changelogs
Demo
카카오 로그인 Example Project 데모 화면
위 프로젝트는
KakaoLoginExample폴더에서 확인 가능합니다.
Tutorial
라이브러리를 더욱 편리하게 사용하기 위해서 Youtube 영상을 제작했습니다.
Getting started
해당 라이브러리는 3.0.0 이후 부터는 react-native 0.61이상을 지원합니다. 카카오 라이브러리 지원이 아래 버전부터는 지원이 끊길 예정이므로 참고해주시기 바랍니다. 과거에는 카카오 라이브러리 레거시 iOS와 카카오 라이브러리 레거시 Android 버전을 쓰고 있었습니다.
Installation
yarn add @react-native-seoul/kakao-loginReact Native 0.60.X이상부터는 Auto linking을 지원합니다. 따라서 설치는 매우 간편합니다.
iOS의 경우 yarn add @react-native-seoul/kakao-login 이후 npx pod-install 명령어로 pod 라이브러리만 추가로 설치해주시면 됩니다.
Post Installation
설치가 제대로 되지 않는다면 example project의 설정을 참고하세요 👍
iOS
Pod에서 iOS deployment target이
13.0이상이어야 합니다.ios 카카오 sdk 설치 후의 설정과 관련해서는 공식문서 - 카카오 로그인 > 설정하기를 참고해주세요. 해당 가이드를 통해 카카오 개발자 페이지에서 본인의 어플리케이션을 생성해주세요.
공식문서 - 개발 프로젝트 설정 을 참고하여
info.plist,URL Types및 커스텀 스킴 추가 등 기타 필요한 세팅들을 프로젝트에 추가해줍니다. 아래카카오 네이티브앱 아이디를 적어주세요문구를 잘 확인하시여 본인의 Kakao App Key로 변경해주세요.
<key>CFBundleURLTypes</key>
<array>
+ <dict>
+ <key>CFBundleTypeRole</key>
+ <string>Editor</string>
+ <key>CFBundleURLSchemes</key>
+ <array>
+ <string>kakao{카카오 네이티브앱 아이디를 적어주세요}</string>
+ </array>
+ </dict>
</array>
<key>CFBundleVersion</key>
<string>1</string>
+ <key>KAKAO_APP_KEY</key>
+ <string>{카카오 네이티브앱 아이디를 적어주세요}</string>
+ <key>KAKAO_APP_SCHEME</key> // 선택 사항 멀티 플랫폼 앱 구현 시에만 추가하면 됩니다
+ <string>{카카오 앱 스킴을 적어주세요}</string> // 선택 사항
+ <key>LSApplicationQueriesSchemes</key>
+ <array>
+ <string>kakaokompassauth</string>
+ <string>storykompassauth</string>
+ <string>kakaolink</string>
+ </array>3.0.0버전부터는 swift 버전의 kakao sdk를 활용하므로 Swift Bridging Header를 추가해야할 수 있습니다.AppDelegate.m파일에 해당 부분을 추가해주세요. 이는 카카오톡 앱이 깔려 있을시 올바로 데이터를 받아오기 위함입니다 #193.Project => Targets 아래 앱 선택 => General 탭으로 이동해서 Bundle Identifier가 본인의 카카오 앱과 동일한지 확인해주세요.
여러 라이브러리에서 동일한 버전의 SDK를 써야 하는 경우
Podfile에 아래와 같이 추가하여 SDK 버전을 강제로 지정할 수 있습니다.# 없는 경우에는 package.json의 sdkVersions.ios.kakao를 따릅니다. $KakaoSDKVersion=YOUR_KAKAO_SDK_VERSION
Android
키 해시 등록을 진행해주세요. 자바 코드로 구하는 방법이 제일 확실합니다.
AUTHORIZATION_FAILED: invalid android_key_hash or ios_bundle_id or web_site_urlReact Native 0.60.x 부터 템플릿에 기본적으로 디버그 키스토어가 포함되어 있습니다. (
project/android/app에 디버그 키스토어가 존재합니다.) 기본 디버그 키스토어의 key hash 는Xo8WBi6jzSxKDVR4drqm84yr9iU=를 사용하시면 됩니다.템플릿에서 기본 제공되는것 이외의 키스토어에서 key hash 를 추출하기 위해서는 아래의 명령어를 사용하세요
글로벌 debug keystore 에서 key hash 추출
keytool -exportcert -alias androiddebugkey -keystore ~/.android/debug.keystore -storepass android -keypass android | openssl sha1 -binary | openssl base64특정 경로의 keystore 에서 key hash 추출
keytool -exportcert -alias {my-app-key-alias} -keystore {your-key-path}/{my-app-key}.keystore -storepass android -keypass android | openssl sha1 -binary | openssl base64Redirect URI 설정
카카오 로그인 기능을 구현하기 위해서는 리다이렉션(Redirection)을 통해 Request Code를 받아야 합니다. 그러기 위해서는 아래 코드를
AndroidManifest.xml에 추가해주세요. 그리고카카오 네이티브 앱 key를 입력해주세요텍스트를 본인의 카카오 네이티브 키로 변경해주시면 됩니다. (Android 12(API 31) 이상을 타깃으로 하는 앱인 경우,exported요소를 반드시 "true"로 선언해야 합니다.)<activity android:name="com.kakao.sdk.auth.AuthCodeHandlerActivity" android:exported="true"> <intent-filter> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> <category android:name="android.intent.category.BROWSABLE" /> <!-- Redirect URI: "kakao{NATIVE_APP_KEY}://oauth“ --> <data android:host="oauth" android:scheme="kakao{카카오 네이티브 앱 key를 입력해주세요}" /> </intent-filter> </activity>
app/src/main/res/values/strings.xml을 열어 다음을 추가합니다<resources> <string name="app_name">KakaoLoginExample</string> + <string name="kakao_app_key">your_app_key</string> </resources>공식문서-토큰관리 에서 참고할 수 있듯이 Android 카카오 SDK는 액세스 토큰을 자동 갱신해줍니다.
컴파일 에러가 나면
build.gradle에서 android sdk compile version 등 빌드 sdk 버전을 맞춰주세요.(Optional) 앱 배포 시, 코드 축소, 난독화, 최적화를 하는 경우, 카카오 SDK를 제외해야 하기 때문에 ProGuard 규칙 파일에 다음 코드를 추가해주세요.
-keep class com.kakao.sdk.**.model.* { <fields>; }
-keep class * extends com.google.gson.TypeAdapter
# https://github.com/square/okhttp/pull/6792
-dontwarn org.bouncycastle.jsse.**
-dontwarn org.conscrypt.*
-dontwarn org.openjsse.**- Gradle 및 카카오 SDK의 버전을 변경해야 하는 경우, android/gradle.properties 에 있는 항목들을 확인하고, Android gradle의 root project의 ext에
RNKakaoLogins_를 제외한 버전을 명시해주세요.
EXPO (Expo Go, Snack 사용 불가, Development Build(EAS, local build)만 가능)
- Android의 Kakao SDK Maven Repository를 선언하기 위해 필요한 의존성을 추가합니다.
npx expo install expo-build-properties- app.json 파일을 아래와 같이 수정합니다.
{
"expo": {
...
"plugins": [
...,
[
"@react-native-seoul/kakao-login",
{
"kakaoAppKey": "{{kakao api key}}",
"overrideKakaoSDKVersion": "2.11.2", // Optional,
"kotlinVersion": "1.9.0" // #392
}
],
[
"expo-build-properties",
{
"android": {
"extraMavenRepos": ["https://devrepo.kakao.com/nexus/content/groups/public/"]
}
}
]
],
...
}
} - (Optional) Android에서 난독화를 사용하실 경우, Expo BuildProperties 를 이용해 Proguard Rule을 공식 문서와 같이 설정해줍니다.
Methods
| Func | Param | Return | Description |
|---|---|---|---|
| login | Promise{KakaoOAuthToken} | 로그인 (카카오톡에 접근할 수 없다면 loginWithKakaoAccount 호출) | |
| loginWithKakaoAccount | Promise{KakaoOAuthToken} | 카카오계정으로 로그인 (기본 웹 브라우저(CustomTabs)에 있는 카카오계정 cookie 로 사용자를 인증하고 OAuthToken 발급) | |
| getProfile | Promise{KakaoProfile} | 프로필 불러오기 | |
| logout | Promise{string} | 로그아웃 | |
| unlink | Promise{string} | 연결끊기 | |
| getAccessToken | Promise{KakaoAccessTokenInfo} | 액세스 토큰 조회 |
프로필 가져오기 - getProfile => KakaoProfile
| iOS | Android | type | Description | |
|---|---|---|---|---|
accessToken | ✓ | ✓ | string | 토큰 |
refreshToken? | ✓ | ✓ | string | 리프레쉬 토큰 |
idToken? | ✓ | ✓ | string | OpenID Connect 확장 기능을 통해 발급되는 ID 토큰 |
accessTokenExpiresAt? | ✓ | ✓ | Date | 토큰 만료 시간 |
refreshTokenExpiresAt? | ✓ | ✓ | Date | 리프레쉬 토큰 만료 시간, 구버전 SDK로 이미 로그인이 되어있었다면 null이 반환될 수 있습니다. |
scopes | ✓ | ✓ | string[] | 사용자로 부터 받은 권한 |
배송지 가져오기 - shippingAddresses => KakaoShippingAddresses
| iOS | Android | type | Description | |
|---|---|---|---|---|
userId | ✓ | ✓ | string | 사용자 Id |
needsAgreement | ✓ | ✓ | boolean | 배송지 제공에 대한 사용자의 동의 필요 여부 |
shippingAddresses | ✓ | ✓ | Array | 사용자가 소유한 배송지 목록 |
배송지 정보 (KakaoShippingAddress)
| iOS | Android | type | Description | |
|---|---|---|---|---|
id | ✓ | ✓ | string | 배송지 아이디 |
name | ✓ | ✓ | string | 배송지명 |
isDefault | ✓ | ✓ | boolean | 기본 배송지 여부 |
updatedAt | ✓ | ✓ | Date | 마지막 배송지정보 수정시각 |
type | ✓ | ✓ | string | 배송지 타입(Old, New) |
baseAddress | ✓ | ✓ | string | 주소 검색을 통해 자동으로 입력되는 기본 주소 |
detailAddress | ✓ | ✓ | string | 기본 주소에 추가하는 상세 주소 |
receiverName | ✓ | ✓ | string | 수령인 이름 |
receiverPhoneNumber1 | ✓ | ✓ | string | 수령인 연락처 |
receiverPhoneNumber2 | ✓ | ✓ | string | 수령인 추가 연락처 |
zoneNumber | ✓ | ✓ | string | 도로명 주소 우편번호. 배송지 타입이 NEW(도로명 주소)인 경우 반드시 존재함 |
zipCode | ✓ | ✓ | string | 지번 주소 우편번호. 배송지 타입이 OLD(지번 주소)여도 값이 없을 수 있음 |
서비스 약관 동의 내역 확인하기 -> serviceTerms => KakaoUserServiceTerms
카카오싱크를 도입한 서비스만 사용할 수 있는 기능입니다.
| iOS | Android | type | Description | |
|---|---|---|---|---|
userId | ✓ | ✓ | number? | 회원 번호 |
serviceTerms | ✓ | ✓ | KakaoServiceTerms[]? | 조회한 서비스 약관 목록 |
조회한 서비스 약관 목록 (KakaoServiceTerms)
| iOS | Android | type | Description | |
|---|---|---|---|---|
tag | ✓ | ✓ | string | 3rd에서 동의한 약관의 항목들을 정의한 값 |
agreed | ✓ | ✓ | boolean | 동의 여부 |
agreedAt | ✓ | ✓ | string? | 최근 동의 시각 |
required | ✓ | ✓ | boolean | 필수 동의 여부 |
revocable | ✓ | ✓ | boolean | 철회 가능 여부 |
React-native-web
1.RestApiKey랑 redirectUrl을 포함한 아래 링크로 href 링크를 열어서 code를 가져옵니다
const kakaoUrl = https://kauth.kakao.com/oauth/authorize?client_id=${restApiKey}&redirect_uri=${redirectUrl}&response_type=code;
redirectUrl이 http://localhost:3000 일때 아래와같이 redirectUrl에 code파라미터가 붙은 url이 들어와집니다
http://localhost:3000/?code=Ss32OM1_yUybn5dtEQ-XT8EZfV24BKC_GIeIvFPz7_wHorYXtij9JFQcMuGtGdzxQc3Vlwopb1UAAAGCizvuCw code= 뒤쪽부분을 split해서 토큰 발급시 필요한 code를 얻을 수 있습니다 react-native-web에서는 app과 다르게 restApikey, redirecturl을 code와 같이 직접 넣어줘야 합니다
Methods (Web)
| Func | Param | Return | Description |
|---|---|---|---|
| login | restApiKeyWeb, redirectUrlWeb, codeWeb | Promise{KakaoOAuthWebToken} | 로그인 |
| loginWithKakaoAccount | 웹 지원 x | ||
| getProfile | tokenWeb | Promise{KakaoProfile} | 프로필 불러오기 |
| shippingAddresses | tokenWeb | Promise{KakaoShippingAddresses} | 배송지 정보 불러오기 |
| logout | tokenWeb | Promise{string} | 로그아웃 |
| unlink | tokenWeb | Promise{string} | 연결끊기 |
| getAccessToken | 웹 지원 x |
Usage
Sample Code
const signInWithKakao = async (): Promise<void> => {
const token: KakaoOAuthToken = await login();
setResult(JSON.stringify(token));
};
const signOutWithKakao = async (): Promise<void> => {
const message = await logout();
setResult(message);
};
const getKakaoProfile = async (): Promise<void> => {
const profile: KakaoProfile = await getProfile();
setResult(JSON.stringify(profile));
};
const getKakaoShippingAddresses = async (): Promise<void> => {
const addresses: KakaoShippingAddresses = await shippingAddresses();
setResult(JSON.stringify(addresses));
};
const getKakaoServiceTerms = async (): Promise<void> => {
const serviceTerms: KakaoUserServiceTerms = await serviceTerms();
setResult(JSON.stringify(serviceTerms))
}
const unlinkKakao = async (): Promise<void> => {
const message = await unlink();
setResult(message);
};How to run example project
clone받은 레포에서KakaoLoginExample폴더로 이동합니다cd KakaoLoginExample필요한 모듈을 설치 합니다(
preinstall이 실행됩니다)yarn프로젝트 실행
KAKAO_APP_KEY등 필요한 SDK 연동 설정은 기본으로 되어 있습니다.- 본인 앱의 키로 변경하고 테스트 하셔도 무방합니다. 단
PR을 날리실 때는 삭제하고 날려주세요.
- 본인 앱의 키로 변경하고 테스트 하셔도 무방합니다. 단
yarn startyarn iosoryarn android로 앱 실행iOS앱이 실행되지 않을 때는XCode를 열고 테스트 해주세요. 이는 RN0.64.0에서 발생되고 있는 문제입니다.
- ios의 경우
ios폴더에서pod install을 먼저 실행해 주세요. 프로젝트 폴더에서npx pod-install로 이용하셔도 무방합니다.
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago