Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

I am getting the error in my flutter project when implementing google sign in

Here I have implemented google login. i have used the google_sign_in 4.1.4 please help me to find out where am i doing mistake or missing something. Thanks in advance..!!

this error Rejecting re-init on previously-failed class java.lang.Class: java.lang.NoClassDefFoundError: Failed resolution of: Landroidx/lifecycle/LifecycleEventObserver; I/zygote64(27656): at java.lang.Object java.lang.Class.newInstance() (Class.java:-2)

 onTap: () async{

                            _signIn(context)
                                .then((FirebaseUser user) => print(user))
                                .catchError((e) => print(e));

                          },
 final FirebaseAuth _auth = FirebaseAuth.instance;
  final GoogleSignIn _googleSignIn = new GoogleSignIn();

  Future<FirebaseUser> _signIn(BuildContext context) async{
    GoogleSignInAccount googleSignInAccount = await _googleSignIn.signIn(); //crash on this line
    GoogleSignInAuthentication gSA = await googleSignInAccount.authentication;
    final AuthCredential  credential  = GoogleAuthProvider.getCredential(idToken: gSA.idToken, accessToken: gSA.accessToken);
    final AuthResult authResult = await _auth.signInWithCredential(credential);
    final FirebaseUser userDetails = authResult.user;
    ProviderDetails providerInfo = new ProviderDetails(userDetails.providerId);
    List<ProviderDetails> providerData = new List<ProviderDetails>();
    providerData.add(providerInfo);

    UserDetails details = new UserDetails(
      userDetails.providerId,
      userDetails.displayName,
      userDetails.photoUrl,
      userDetails.email,
      providerData,
    );

 Navigator.push(
      context,
      new MaterialPageRoute(
        builder: (context) => new ChooseCollegeScreen(),
      ),
    );

    return userDetails;
}



here is my error log=========>

Rejecting re-init on previously-failed class java.lang.Class<androidx.activity.ComponentActivity$2>: java.lang.NoClassDefFoundError: Failed resolution of: Landroidx/lifecycle/LifecycleEventObserver;
I/zygote64(27656):   at java.lang.Object java.lang.Class.newInstance() (Class.java:-2)
I/zygote64(27656):   at android.app.Activity android.app.Instrumentation.newActivity(java.lang.ClassLoader, java.lang.String, android.content.Intent) (Instrumentation.java:1175)
I/zygote64(27656):   at android.app.Activity android.app.ActivityThread.performLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent) (ActivityThread.java:2708)
I/zygote64(27656):   at void android.app.ActivityThread.handleLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:2895)
I/zygote64(27656):   at void android.app.ActivityThread.-wrap11(android.app.ActivityThread, android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:-1)
I/zygote64(27656):   at void android.app.ActivityThread$H.handleMessage(android.os.Message) (ActivityThread.java:1616)
I/zygote64(27656):   at void android.os.Handler.dispatchMessage(android.os.Message) (Handler.java:106)
I/zygote64(27656):   at void android.os.Looper.loop() (Looper.java:176)
I/zygote64(27656):   at void android.app.ActivityThread.main(java.lang.String[]) (ActivityThread.java:6651)
I/zygote64(27656):   at java.lang.Object java.lang.reflect.Method.invoke(java.lang.Object, java.lang.Object[]) (Method.java:-2)
I/zygote64(27656):   at void com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run() (RuntimeInit.java:547)
I/zygote64(27656):   at void com.android.internal.os.ZygoteInit.main(java.lang.String[]) (ZygoteInit.java:824)
I/zygote64(27656): Caused by: java.lang.ClassNotFoundException: Didn't find class "androidx.lifecycle.LifecycleEventObserver" on path: DexPathList[[zip file "/data/app/moon.campushaat.com-_doLzLlPm2QzmtHCYUYAfg==/base.apk"],nativeLibraryDirectories=[/data/app/moon.campushaat.com-_doLzLlPm2QzmtHCYUYAfg==/lib/arm64, /data/app/moon.campushaat.com-_doLzLlPm2QzmtHCYUYAfg==/base.apk!/lib/arm64-v8a, /system/lib64, /system/vendor/lib64]]
I/zygote64(27656):   at java.lang.Class dalvik.system.BaseDexClassLoader.findClass(java.lang.String) (BaseDexClassLoader.java:125)
I/zygote64(27656):   at java.lang.Class java.lang.ClassLoader.loadClass(java.lang.String, boolean) (ClassLoader.java:379)
I/zygote64(27656):   at java.lang.Class java.lang.ClassLoader.loadClass(java.lang.String) (ClassLoader.java:312)
I/zygote64(27656):   at java.lang.Object java.lang.Class.newInstance() (Class.java:-2)
I/zygote64(27656):   at android.app.Activity android.app.Instrumentation.newActivity(java.lang.ClassLoader, java.lang.String, android.content.Intent) (Instrumentation.java:1175)
I/zygote64(27656):   at android.app.Activity android.app.ActivityThread.performLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent) (ActivityThread.java:2708)
I/zygote64(27656):   at void android.app.ActivityThread.handleLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:2895)
I/zygote64(27656):   at void android.app.ActivityThread.-wrap11(android.app.ActivityThread, android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:-1)
I/zygote64(27656):   at void android.app.ActivityThread$H.handleMessage(android.os.Message) (ActivityThread.java:1616)
I/zygote64(27656):   at void android.os.Handler.dispatchMessage(android.os.Message) (Handler.java:106)
I/zygote64(27656):   at void android.os.Looper.loop() (Looper.java:176)
I/zygote64(27656):   at void android.app.ActivityThread.main(java.lang.String[]) (ActivityThread.java:6651)
I/zygote64(27656):   at java.lang.Object java.lang.reflect.Method.invoke(java.lang.Object, java.lang.Object[]) (Method.java:-2)
I/zygote64(27656):   at void com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run() (RuntimeInit.java:547)
I/zygote64(27656):   at void com.android.internal.os.ZygoteInit.main(java.lang.String[]) (ZygoteInit.java:824) 
like image 359
Dharam Dutt Mishra Avatar asked Mar 02 '20 10:03

Dharam Dutt Mishra


People also ask

How do you implement Sign in with Google in flutter?

Step 1: First create the flutter project in your IDE. Step 2: After that just remove the default code and start from scratch. Step 3: Now just import the material library and call the runApp( ) function into the main function name as GoogleSignIn. Step 4: Now make a stateful widget with the name 'GoogleSignIn'.

Does Google use flutter?

Flutter is supported and used by Google, trusted by well-known brands around the world, and maintained by a community of global developers.


Video Answer


1 Answers

Make sure your app migrated to androidx. (gradle.properties file contains line android.useAndroidX=true)

Also this error may be related to apk-file size (over 64K limit) on old Android devices (API < 21). Either change minSdkVersion to 21+, or configure your app for multidex.

In module-level build.gradle file add the multidex library as a dependency:

android {
    defaultConfig {
        ...
        minSdkVersion 15 
        targetSdkVersion 29
        multiDexEnabled true
    }
    ...
}

dependencies {
  ...
  implementation 'androidx.multidex:multidex:2.0.1'
}
like image 153
Spatz Avatar answered Oct 24 '22 06:10

Spatz