我有 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/
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我遵循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
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c
我正在尝试编写一个将文件上传到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
我克隆了一个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
在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
我是Google云的新手,我正在尝试对其进行首次部署。我的第一个部署是RubyonRails项目。我基本上是在关注thisguideinthegoogleclouddocumentation.唯一的区别是我使用的是我自己的项目,而不是他们提供的“helloworld”项目。这是我的app.yaml文件runtime:customvm:trueentrypoint:bundleexecrackup-p8080-Eproductionconfig.ruresources:cpu:0.5memory_gb:1.3disk_size_gb:10当我转到我的项目目录并运行gcloudprevie
我有两个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
这个问题在这里已经有了答案: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]]
尝试在我的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