本文介绍了Flutter:如何使用Firebase PhoneNumberAuth修复与设备的丢失连接错误的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在实现phoneNumberAuth注册.但是有一个问题

I am implementing phoneNumberAuth signup. But there's a problem

当我单击authbottom时,终止了iOS应用

When i clicked authbottom, terminated iOS app

代码:

String smsCode, verificationId;

  Future<void> verifyPhone() async {
    final PhoneCodeAutoRetrievalTimeout autoRetrieve = (String verId) {
      this.verificationId = verId;
    };

    final PhoneCodeSent smsCodeSent = (String verId, [int forceCodeResend]) {
      this.verificationId = verId;
      print('asd');
      smsCodeDialog(context).then((value) {
        print('Signed in');
      });
    };

    final PhoneVerificationCompleted verificationCompleted = (AuthCredential credential) {
      print('verified');
    };

    final PhoneVerificationFailed verfiFailed = (AuthException exception) {
      print('${exception.message}+ddddddddddd');
    };

    await FirebaseAuth.instance.verifyPhoneNumber(
      phoneNumber: this.phoneNo,
      timeout: const Duration(seconds: 5),
      verificationCompleted: verificationCompleted,
      verificationFailed: verfiFailed,
      codeSent: smsCodeSent,
      codeAutoRetrievalTimeout: autoRetrieve,
    );
  }

  Future<bool> smsCodeDialog(BuildContext context) {
    return showDialog(
        context: context,
        barrierDismissible: false,
        builder: (BuildContext context) {
          return AlertDialog(
            title: Text('SMS 코드를 입력해주세요'),
            content: TextField(
              onChanged: (value) {
                this.smsCode = value;
              },
            ),
            contentPadding: EdgeInsets.all(10),
            actions: <Widget>[
              FlatButton(
                child: Text('Done'),
                onPressed: () {
                  FirebaseAuth.instance.currentUser().then((user) {
                    if (user != null) {
                      Navigator.of(context).pop();
                      Navigator.of(context).pushReplacementNamed('/');
                    } else {
                      Navigator.of(context).pop();
                      SIGNIn();
                    }
                  });
                },
              )
            ],
          );
        });
  }



  SIGNIn() async{
    final AuthCredential credential = PhoneAuthProvider.getCredential(
      verificationId: verificationId,
      smsCode: smsCode,
    );
    print('진행중');
    FirebaseAuth _auth = FirebaseAuth.instance;
    final FirebaseUser user = (await _auth.signInWithCredential(credential)).user;
    final FirebaseUser currentUser = await _auth.currentUser();
    assert(user.uid == currentUser.uid);
    setState(() {
      if(user != null){
        print('success!');
      }else{
        print('sign in failed');
      }
    });
  }

错误代码:


*** First throw call stack:
(
    0   CoreFoundation                      0x00000001169bb8db __exceptionPreprocess + 331
    1   libobjc.A.dylib                     0x0000000115f66ac5 objc_exception_throw + 48
    2   CoreFoundation                      0x00000001169d9c94 -[NSObject(NSObject) doesNotRecognizeSelector:] + 132
    3   CoreFoundation                      0x00000001169c0623 ___forwarding___ + 1443
    4   CoreFoundation                      0x00000001169c2418 _CF_forwarding_prep_0 + 120
    5   Runner                              0x000000010e97d966 -[FIRPhoneAuthProvider internalVerifyPhoneNumber:UIDelegate:completion:] + 118
    6   Runner                              0x000000010e97ccc0 __64-[FIRPhoneAuthProvider verifyPhoneNumber:UIDelegate:completion:]_block_invoke + 272
    7   libdispatch.dylib                   0x0000000115e16ccf _dispatch_call_block_an<…>
Lost connection to device.

我该如何修正我的代码?

How can i do fix my code ?

在有人帮助我之前,我会尝试进行修复

Until someone helped me, i trying doing fix

很难,因为没有太多解释错误.

It's hard because there aren't many explain errors.

如果有人能帮助我,我将不胜感激.

I'd appreciate it if someone would help me.

有人帮助我:(

推荐答案

pop删除顶级窗口小部件.不确定在此之后加上逻辑是一个好主意.最好像这样重新安排代码

pop removes the top level widget. Not sure its a good idea to put logic after that. Better you re-arrange your code like

  // Only gets SMS, no functionality
  Future<String> getSmsCode(BuildContext context) {
    return showDialog<String>(
      context: context,
      barrierDismissible: false,
      builder: (BuildContext context) {
        return AlertDialog(
          title: Text('SMS 코드를 입력해주세요'),
          content: TextField(
            onChanged: (value) {
              this.smsCode = value;
            },
          ),
          contentPadding: EdgeInsets.all(10),
          actions: <Widget>[
            FlatButton(
              child: Text('Done'),
              onPressed: () {
                Navigator.of(context).pop(this.smsCode);
              },
            )
          ],
        );
      },
    );
  }


  SIGNIn() async {
    String smsCode = await getSmsCode(context);
    if (smsCode != null && !smsCode.isNotEmpty) {
      print('User cancelled SMS dialog');
      return;
    }
    final AuthCredential credential = PhoneAuthProvider.getCredential(
      verificationId: verificationId,
      smsCode: smsCode,
    );
    print('진행중');
    FirebaseAuth _auth = FirebaseAuth.instance;
    final FirebaseUser user = (await _auth.signInWithCredential(credential)).user;
    final FirebaseUser currentUser = await _auth.currentUser();
    assert(user.uid == currentUser.uid);
    setState(() {
      if (user != null) {
        print('success!');
      } else {
        print('sign in failed');
      }
    });
  }

现在仅调用SIGNIn,它将首先获取SMS代码,然后使用该SMS代码登录.希望对您有所帮助.

Now only invoke SIGNIn, it will first get SMS code then signin using that SMS code. Hope it helps.

这篇关于Flutter:如何使用Firebase PhoneNumberAuth修复与设备的丢失连接错误的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

09-26 21:53