草庐IT

flutter - 错误 Flutter Firebase Auth 和 Google 登录

coder 2023-07-22 原文

我有 2 个 flutter 应用程序作为我的学习。他们都使用 firebase auth 和 google 使用完全相同的代码登录。我设法从这个 url 复制了这个片段 但是有不同的 firebase 应用程序。

第一个应用程序完全运行良好。但第二个有点神秘。 我不知道为什么会出现此错误

E/MethodChannel#plugins.flutter.io/firebase_auth( 9042): Failed to handle method call
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042): java.lang.NullPointerException: Attempt to invoke virtual method 'void com.google.firebase.auth.FirebaseAuth.addAuthStateListener(com.google.firebase.auth.FirebaseAuth$AuthStateListener)' on a null object reference
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at io.flutter.plugins.firebaseauth.FirebaseAuthPlugin.handleStartListeningAuthState(FirebaseAuthPlugin.java:629)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at io.flutter.plugins.firebaseauth.FirebaseAuthPlugin.onMethodCall(FirebaseAuthPlugin.java:149)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at io.flutter.plugin.common.MethodChannel$IncomingMethodCallHandler.onMessage(MethodChannel.java:201)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at io.flutter.embedding.engine.dart.DartMessenger.handleMessageFromDart(DartMessenger.java:88)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at io.flutter.embedding.engine.FlutterJNI.handlePlatformMessage(FlutterJNI.java:219)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at android.os.MessageQueue.nativePollOnce(Native Method)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at android.os.MessageQueue.next(MessageQueue.java:326)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at android.os.Looper.loop(Looper.java:160)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at android.app.ActivityThread.main(ActivityThread.java:6669)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at java.lang.reflect.Method.invoke(Native Method)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
E/MethodChannel#plugins.flutter.io/firebase_auth( 9042):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
D/EGL_emulation( 9042): eglMakeCurrent: 0xc9976640: ver 2 0 (tinfo 0xe1031ea0)
E/flutter ( 9042): [ERROR:flutter/lib/ui/ui_dart_state.cc(148)] Unhandled Exception: PlatformException(error, Attempt to invoke virtual method 'void com.google.firebase.auth.FirebaseAuth.addAuthStateListener(com.google.firebase.auth.FirebaseAuth$AuthStateListener)' on a null object reference, null)

当我使用 google 登录时出现此错误。

E/MethodChannel#plugins.flutter.io/google_sign_in( 9042): Failed to handle method call
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042): android.content.ActivityNotFoundException: Unable to find explicit activity class {com.example.tokoku_flutter/com.google.android.gms.auth.api.signin.internal.SignInHubActivity}; have you declared this activity in your AndroidManifest.xml?
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:2005)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.app.Instrumentation.execStartActivity(Instrumentation.java:1673)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.app.Activity.startActivityForResult(Activity.java:4586)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.app.Activity.startActivityForResult(Activity.java:4544)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at io.flutter.plugins.googlesignin.GoogleSignInPlugin$Delegate.signIn(GoogleSignInPlugin.java:292)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at io.flutter.plugins.googlesignin.GoogleSignInPlugin.onMethodCall(GoogleSignInPlugin.java:77)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at io.flutter.plugin.common.MethodChannel$IncomingMethodCallHandler.onMessage(MethodChannel.java:201)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at io.flutter.embedding.engine.dart.DartMessenger.handleMessageFromDart(DartMessenger.java:88)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at io.flutter.embedding.engine.FlutterJNI.handlePlatformMessage(FlutterJNI.java:219)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.os.MessageQueue.nativePollOnce(Native Method)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.os.MessageQueue.next(MessageQueue.java:326)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.os.Looper.loop(Looper.java:160)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at android.app.ActivityThread.main(ActivityThread.java:6669)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at java.lang.reflect.Method.invoke(Native Method)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
E/MethodChannel#plugins.flutter.io/google_sign_in( 9042):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
D/AndroidRuntime( 9042): Shutting down VM
E/AndroidRuntime( 9042): FATAL EXCEPTION: main
E/AndroidRuntime( 9042): Process: com.example.tokoku_flutter, PID: 9042
E/AndroidRuntime( 9042): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=53293, result=0, data=null} to activity {com.example.tokoku_flutter/com.example.tokoku_flutter.MainActivity}: java.lang.IllegalStateException: Reply already submitted
E/AndroidRuntime( 9042):    at android.app.ActivityThread.deliverResults(ActivityThread.java:4360)
E/AndroidRuntime( 9042):    at android.app.ActivityThread.handleSendResult(ActivityThread.java:4402)
E/AndroidRuntime( 9042):    at android.app.servertransaction.ActivityResultItem.execute(ActivityResultItem.java:49)
E/AndroidRuntime( 9042):    at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
E/AndroidRuntime( 9042):    at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
E/AndroidRuntime( 9042):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808)
E/AndroidRuntime( 9042):    at android.os.Handler.dispatchMessage(Handler.java:106)
E/AndroidRuntime( 9042):    at android.os.Looper.loop(Looper.java:193)
E/AndroidRuntime( 9042):    at android.app.ActivityThread.main(ActivityThread.java:6669)
E/AndroidRuntime( 9042):    at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime( 9042):    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
E/AndroidRuntime( 9042):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
E/AndroidRuntime( 9042): Caused by: java.lang.IllegalStateException: Reply already submitted
E/AndroidRuntime( 9042):    at io.flutter.embedding.engine.dart.DartMessenger$Reply.reply(DartMessenger.java:124)
E/AndroidRuntime( 9042):    at io.flutter.plugin.common.MethodChannel$IncomingMethodCallHandler$1.error(MethodChannel.java:209)
E/AndroidRuntime( 9042):    at io.flutter.plugins.googlesignin.GoogleSignInPlugin$Delegate.finishWithError(GoogleSignInPlugin.java:386)
E/AndroidRuntime( 9042):    at io.flutter.plugins.googlesignin.GoogleSignInPlugin$Delegate.onActivityResult(GoogleSignInPlugin.java:524)
E/AndroidRuntime( 9042):    at io.flutter.app.FlutterPluginRegistry.onActivityResult(FlutterPluginRegistry.java:222)
E/AndroidRuntime( 9042):    at io.flutter.app.FlutterActivityDelegate.onActivityResult(FlutterActivityDelegate.java:142)
E/AndroidRuntime( 9042):    at io.flutter.app.FlutterActivity.onActivityResult(FlutterActivity.java:142)
E/AndroidRuntime( 9042):    at android.app.Activity.dispatchActivityResult(Activity.java:7454)
E/AndroidRuntime( 9042):    at android.app.ActivityThread.deliverResults(ActivityThread.java:4353)
E/AndroidRuntime( 9042):    ... 11 more
E/flutter ( 9042): [ERROR:flutter/lib/ui/ui_dart_state.cc(148)] Unhandled Exception: PlatformException(error, Unable to find explicit activity class {com.example.tokoku_flutter/com.google.android.gms.auth.api.signin.internal.SignInHubActivity}; have you declared this activity in your AndroidManifest.xml?, null)
E/flutter ( 9042): #0      StandardMethodCodec.decodeEnvelope 
package:flutter/…/services/message_codecs.dart:564
E/flutter ( 9042): #1      MethodChannel.invokeMethod 
package:flutter/…/services/platform_channel.dart:302
E/flutter ( 9042): <asynchronous suspension>
E/flutter ( 9042): #2      GoogleSignIn._callMethod 
package:google_sign_in/google_sign_in.dart:226
E/flutter ( 9042): <asynchronous suspension>
E/flutter ( 9042): #3      GoogleSignIn._addMethodCall 
package:google_sign_in/google_sign_in.dart:268
E/flutter ( 9042): #4      GoogleSignIn.signIn 
package:google_sign_in/google_sign_in.dart:339
E/flutter ( 9042): #5      AuthService.googleSignIn 
package:tokoku_flutter/services/AuthService.dart:39
E/flutter ( 9042): <asynchronous suspension>
E/flutter ( 9042): #6      _LoginPageState._loginButton.<anonymous closure>.<anonymous closure> 
package:tokoku_flutter/pages/LoginPage.dart:60
E/flutter ( 9042): #7      _InkResponseState._handleTap 
package:flutter/…/material/ink_well.dart:511
E/flutter ( 9042): #8      _InkResponseState.build.<anonymous closure> 
package:flutter/…/material/ink_well.dart:566
E/flutter ( 9042): #9      GestureRecognizer.invokeCallback 
package:flutter/…/gestures/recognizer.dart:166
E/flutter ( 9042): #10     TapGestureRecognizer._checkUp 
package:flutter/…/gestures/tap.dart:240
E/flutter ( 9042): #11     TapGestureRecognizer.handlePrimaryPointer 
package:flutter/…/gestures/tap.dart:177
E/flutter ( 9042): #12     PrimaryPointerGestureRecognizer.handleEvent 
package:flutter/…/gestures/recognizer.dart:436
E/flutter ( 9042): #13     PointerRouter._dispatch 
package:flutter/…/gestures/pointer_router.dart:73
E/flutter ( 9042): #14     PointerRouter.route 
package:flutter/…/gestures/pointer_router.dart:101
E/flutter ( 9042): #15     _WidgetsFlutterBinding&BindingBase&GestureBinding.handleEvent 
package:flutter/…/gestures/binding.dart:221
E/flutter ( 9042): #16     _WidgetsFlutterBinding&BindingBase&GestureBinding.dispatchEvent 
package:flutter/…/gestures/binding.dart:199
E/flutter ( 9042): #17     _WidgetsFlutterBinding&BindingBase&GestureBinding._handlePointerEvent 
package:flutter/…/gestures/binding.dart:156
E/flutter ( 9042): #18     _WidgetsFlutterBinding&BindingBase&GestureBinding._flushPointerEventQueue 
package:flutter/…/gestures/binding.dart:102
E/flutter ( 9042): #19     _WidgetsFlutterBinding&BindingBase&GestureBinding._handlePointerDataPacket 
package:flutter/…/gestures/binding.dart:86
E/flutter ( 9042): #20     _rootRunUnary  (dart:async/zone.dart:1136:13)
E/flutter ( 9042): #21     _CustomZone.runUnary  (dart:async/zone.dart:1029:19)
E/flutter ( 9042): #22     _CustomZone.runUnaryGuarded  (dart:async/zone.dart:931:7)
E/flutter ( 9042): #23     _invoke1  (dart:ui/hooks.dart:233:10)
E/flutter ( 9042): #24     _dispatchPointerDataPacket  (dart:ui/hooks.dart:154:5)
E/flutter ( 9042):
I/Process ( 9042): Sending signal. PID: 9042 SIG: 9
Lost connection to device.
Exited (sigterm)

点击登录按钮后,我的应用程序关闭。

这里是我使用的依赖项:

dependencies:
  flutter:
    sdk: flutter

  # The following adds the Cupertino Icons font to your application.
  # Use with the CupertinoIcons class for iOS style icons.
  cupertino_icons: ^0.1.2
  rxdart: ^0.22.0
  firebase_auth: ^0.11.1
  firebase_core: ^0.4.0+1
  google_sign_in: ^4.0.1+3
  cloud_firestore: ^0.11.0+2
  get_it: ^1.0.3

注意: 我已经在我的 firebase 应用程序中设置了我的 sha key 。 我已经把 googleservice.json 我已经在 gradle 中添加了类路径和依赖项 我已经将我的 flutter 应用程序迁移到 androidX

最佳答案

在为这个问题苦苦挣扎了一段时间后,我找到了 this github issue .

运行 flutter clean 问题就消失了!

关于flutter - 错误 Flutter Firebase Auth 和 Google 登录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56239832/

有关flutter - 错误 Flutter Firebase Auth 和 Google 登录的更多相关文章

  1. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  2. ruby-on-rails - 迷你测试错误 : "NameError: uninitialized constant" - 2

    我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test

  3. ruby-on-rails - 如何在 Rails View 上显示错误消息? - 2

    我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c

  4. 使用 ACL 调用 upload_file 时出现 Ruby S3 "Access Denied"错误 - 2

    我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file

  5. ruby-on-rails - 错误 : Error installing pg: ERROR: Failed to build gem native extension - 2

    我克隆了一个rails仓库,我现在正尝试捆绑安装背景:OSXElCapitanruby2.2.3p173(2015-08-18修订版51636)[x86_64-darwin15]rails-v在您的Gemfile中列出的或native可用的任何gem源中找不到gem'pg(>=0)ruby​​'。运行bundleinstall以安装缺少的gem。bundleinstallFetchinggemmetadatafromhttps://rubygems.org/............Fetchingversionmetadatafromhttps://rubygems.org/...Fe

  6. ruby - #之间? Cooper 的 *Beginning Ruby* 中的错误或异常 - 2

    在Cooper的书BeginningRuby中,第166页有一个我无法重现的示例。classSongincludeComparableattr_accessor:lengthdef(other)@lengthother.lengthenddefinitialize(song_name,length)@song_name=song_name@length=lengthendenda=Song.new('Rockaroundtheclock',143)b=Song.new('BohemianRhapsody',544)c=Song.new('MinuteWaltz',60)a.betwee

  7. ruby-on-rails - 每次我尝试部署时,我都会得到 - (gcloud.preview.app.deploy) 错误响应 : [4] DEADLINE_EXCEEDED - 2

    我是Google云的新手,我正在尝试对其进行首次部署。我的第一个部署是RubyonRails项目。我基本上是在关注thisguideinthegoogleclouddocumentation.唯一的区别是我使用的是我自己的项目,而不是他们提供的“helloworld”项目。这是我的app.yaml文件runtime:customvm:trueentrypoint:bundleexecrackup-p8080-Eproductionconfig.ruresources:cpu:0.5memory_gb:1.3disk_size_gb:10当我转到我的项目目录并运行gcloudprevie

  8. ruby-on-rails - Rails 5 Active Record 记录无效错误 - 2

    我有两个Rails模型,即Invoice和Invoice_details。一个Invoice_details属于Invoice,一个Invoice有多个Invoice_details。我无法使用accepts_nested_attributes_forinInvoice通过Invoice模型保存Invoice_details。我收到以下错误:(0.2ms)BEGIN(0.2ms)ROLLBACKCompleted422UnprocessableEntityin25ms(ActiveRecord:4.0ms)ActiveRecord::RecordInvalid(Validationfa

  9. arrays - 这是 Ruby 中 Array.fill 方法的错误吗? - 2

    这个问题在这里已经有了答案:Arraysmisbehaving(1个回答)关闭6年前。是否应该这样,即我误解了,还是错误?a=Array.new(3,Array.new(3))a[1].fill('g')=>[["g","g","g"],["g","g","g"],["g","g","g"]]它不应该导致:=>[[nil,nil,nil],["g","g","g"],[nil,nil,nil]]

  10. ruby-on-rails - Ruby on Rails 计数器缓存错误 - 2

    尝试在我的RoR应用程序中实现计数器缓存列时出现错误Unknownkey(s):counter_cache。我在这个问题中实现了模型关联:Modelassociationquestion这是我的迁移:classAddVideoVotesCountToVideos0Video.reset_column_informationVideo.find(:all).eachdo|p|p.update_attributes:videos_votes_count,p.video_votes.lengthendenddefself.downremove_column:videos,:video_vot

随机推荐