기본 콘텐츠로 건너뛰기

안드로이드 앱 만들기 : Firebase Auth crash when AGP 8.0


원본출처: 티스토리 바로가기

안드로이드 gradle 이 8.0.x로 넘어가면서 발생한 이슈에 대한 이야기를 적어 두고자 합니다. 

앱을 구현하는 동안에 firebase의 사용자 인증을 사용하고자 했으나, 이것이 인증 오류를 발생시키게 됩니다. 

 

debug에서는 문제가 없었으나, release를 하는 과정에서만  오류를 발생시켜 애를 태우더군요. ㅠㅠ;;

 

Fatal Exception: com.google.firebase.FirebaseException: An internal error has occurred. [ Instantiation of JsonResponse failed! class com.google.android.gms.internal.firebase-auth-api.zzok ]
       at co m.google.firebase.auth.api.internal.zzem.zza(com.google.firebase:firebase-auth@@20.0.0:29) 
       at co m.google.firebase.auth.api.internal.zzfx.zza(com.google.firebase:firebase-auth@@20.0.0:14) 
       at co m.google.firebase.auth.api.internal.zzfs.zza(com.google.firebase:firebase-auth@@20.0.0:44) 
       at co m.google.firebase.auth.api.internal.zzel.zza(com.google.firebase:firebase-auth@@20.0.0:10) 
       at co m.google.firebase.auth.api.internal.zzac.zza(com.google.firebase:firebase-auth@@20.0.0:2) 
       at co m.google.android.gms.common.util.DeviceProperties.zza(com.google.android.gms:play-services-basement@@17.1.1:131) 
       at co m.google.firebase.auth.api.internal.zzfn.zza(com.google.firebase:firebase-auth@@20.0.0:10) 
       at co m.google.firebase.auth.api.internal.zzep.zza(com.google.firebase:firebase-auth@@20.0.0:53)

 

Instantiation of JsonResponse failed!  ...

말 그대로 응답으로 받는 JSON 결과를 분석할 수 없다는 에러를 발생 시킵니다.

 

먼저 gradle의 내용 중에 특별한 것을 보겠습니다. 

 

buildTypes {     debug {         resValue("string", "ADMOB_APP_ID", localProperties.getProperty("ADMOB_APP_ID"))         resValue("string", "ADMOB_BANNER_ID", localProperties.getProperty("ADMOB_BANNER_ID"))     }     release {         resValue("string", "ADMOB_APP_ID", localProperties.getProperty("ADMOB_APP_ID"))         resValue("string", "ADMOB_BANNER_ID", localProperties.getProperty("ADMOB_BANNER_ID"))         shrinkResources true         minifyEnabled true         proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'     } }

debug 시에는 사용하지 않으나, release을 할 때 사용하게 되는 2가지가 있습니다. 코드 난독화와 압축을 이한 선택 사항입니다.  playstore에 게시를 하고자 할 때 선택 해야 하는 요소들 중에 하나입니다.  

 

이유는 앱의 크기를 조금이라도 줄여야 한다는 구글의 압박(?)이 있고,  난독화를 통해 앱을 디버깅하려는 분에게 피곤함(?)을 남겨 두기 위해서입니다. 

 

그래도 proguard 설정을 통해서 난독화 등에서 제외시킬 수 있도록 하고 있기 때문에 꼭 필요한 부분은 제외 등록을 해서 처리를 하고 있기는 합니다. 

 

아무튼 이번에 하고자 하는 이야기의 주된 목적은 압축을 해서 앱 크기를 줄이는 처리를 진행하는 동안에 release 된 앱이 오류를 발생시킨다는 것입니다.  Instantiation of JsonResponse failed!...

 

https://github.com/firebase/firebase-android-sdk/issues/2124

 

Firebase Auth crash when R8 full mode obfuscation enabled · Issue #2124 · firebase/firebase-android-sdk

[READ] Step 1: Are you in the right place? Y [REQUIRED] Step 2: Describe your environment Android Studio version: 4.0 Firebase Component: Auth Component version: 20.0.0 [REQUIRED] Step 3: Describe ...

github.com

이미 많은 개발자들이 같은 증상에 대한 고민을 하고 있었더군요.  아무튼 그 덕분에  며칠을 허비하기는 했으나, 그 결론을 오늘에서야 내릴 수 있게 되었습니다. 

 

조치 방안

먼저 progurad-rules.pro 파일에 아래와 같이 추가해 주었습니다. 

 

 -keep public class com.google.firebase.** {*;} -keep class com.google.android.gms.internal.** {*;} -keepclasseswithmembers class com.google.firebase.FirebaseException

다음은 gradle.properties 파일에 추가해 주었습니다. 

# firebase auth minifyEnabled = true 설정시 인증 오류 JSON 파싱 안되요... android.enableR8.fullMode=true

 

그리고 project의 gradle 파일의 설정은 다음과 같이 수정해 주었습니다. 

buildscript {     ext {         compose_version = '1.4.3'         raamcosta_version = '1.8.41-beta'     }     dependencies {         classpath 'com.google.gms:google-services:4.3.15'         classpath 'com.android.tools.build:gradle:8.0.1'         classpath 'com.google.firebase:firebase-crashlytics-gradle:2.9.5'     } }// Top-level build file where you can add configuration options common to all sub-projects/modules. plugins {     id 'com.android.application' version '8.0.1' apply false     id 'com.android.library' version '8.0.1' apply false     id 'org.jetbrains.kotlin.android' version '1.8.10' apply false } 

gradle 버전이 8.0.1 이 현재 수준에서는 최신인 듯합니다. 그걸 사용하기 위해서  어느 날 문득 나타난 오류(?)와의 대면에서 며칠을 보냈습니다. ㅠㅠ;;

 

아무튼 이제 그 오류에서 해소되어 이렇게 정리된 글을 적어 두고자 합니다.  아닌가? ㅋ~

 

앱의 이메일 을 이용한 인증 화면

 

오늘도 즐~ 코딩 하세요.

쿠팡링크 쿠팡와우 로켓프래쉬 로켓패션
이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다.

댓글

이 블로그의 인기 게시물

안드로이드 앱 만들기 : onBackPressed 가 deprecated 되었다니 ?

원본출처: 티스토리 바로가기 onBackPressed 가 deprecated 되었다? 이제 우리는 구글이 제안하는 안드로이드 13에 타기팅하는 앱을 제출 해야만 하는 시기에 도달하고 있습니다.  구글이 새로운 안드로이드 버전을 배포하기 시작하면서 오래된 안드로이드에 대한 게시를 제한 합니다.    그래서 이번에 API 33 인 안드로이드 13에 타겟팅 하는 앱을 작성해 보았습니다. 그러다 만난 몇 가지 사용 제한이 되는 것들에 대한 정리를 해 두고자 합니다.    onBackPressed는 사용자가 뒤로 가기 버튼을 클릭하는 경우 제어를 하기 위해서 사용했던 함수 입니다. MainActivity 에서 최종적으로 뒤로 가기를 클릭 하는 경우 앱을 종료시키는 기능도 사용이 되는 함수였는 데...   안드로이드 13에서는 더 이상 사용할 수 없는 (?)  - 사용은 가능 하나 소스 코드에 중간 줄이 생긴 모양을 보면서 코드를 지속적으로 봐야 합니다.    onBackPressed 어떻게 해소를 하면 될까요?   CallBack을 하나 만들어 봅니다. private val callback = object : OnBackPressedCallback(true) { override fun handleOnBackPressed() { doCloseApps() } } 다른 건 없고 이런 모양으로 callback 함수를 하나 만들어 둡니다.  그러고 onCreate 에서 이 callback 이 호출 되도록 한 줄 넣어 주는 것으로 그 코딩은 마무리 됩니다.    @RequiresApi(Build.VERSION_CODES.TIRAMISU) override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(sav...

개인정보처리방침 안내

 billcoreaTech('https://billcoreatech.blogspot.com/'이하 'https://billcoreatech.blogspot')은(는) 「개인정보 보호법」 제30조에 따라 정보주체의 개인정보를 보호하고 이와 관련한 고충을 신속하고 원활하게 처리할 수 있도록 하기 위하여 다음과 같이 개인정보 처리방침을 수립·공개합니다. ○ 이 개인정보처리방침은 2021년 8월 26부터 적용됩니다. 제1조(개인정보의 처리 목적) billcoreaTech('https://billcoreatech.blogspot.com/'이하 'https://billcoreatech.blogspot')은(는) 다음의 목적을 위하여 개인정보를 처리합니다. 처리하고 있는 개인정보는 다음의 목적 이외의 용도로는 이용되지 않으며 이용 목적이 변경되는 경우에는 「개인정보 보호법」 제18조에 따라 별도의 동의를 받는 등 필요한 조치를 이행할 예정입니다. 1. 서비스 제공 맞춤서비스 제공을 목적으로 개인정보를 처리합니다. 제2조(개인정보의 처리 및 보유 기간) ① billcoreaTech은(는) 법령에 따른 개인정보 보유·이용기간 또는 정보주체로부터 개인정보를 수집 시에 동의받은 개인정보 보유·이용기간 내에서 개인정보를 처리·보유합니다. ② 각각의 개인정보 처리 및 보유 기간은 다음과 같습니다. 1.<서비스 제공> <서비스 제공>와 관련한 개인정보는 수집.이용에 관한 동의일로부터<사용자의 설정시간>까지 위 이용목적을 위하여 보유.이용됩니다. 보유근거 : 앱의 기본기능 활용에 필요한 위치정보 제3조(개인정보의 제3자 제공) ① billcoreaTech은(는) 개인정보를 제1조(개인정보의 처리 목적)에서 명시한 범위 내에서만 처리하며, 정보주체의 동의, 법률의 특별한 규정 등 「개인정보 보호법」 제17조 및 제18조에 해당하는 경우에만 개인정보를 제3자에게 제공합니다. ② billcoreaTech...