我正在尝试使用一个离子对电话身份验证插件,我找到了此链接:https://github.com/sajTempler/IonicFirebasePhoneAuth,默认情况下,国家/地区代码已硬编码为47,所以我将其更改为55,这是我的CC,但是我不确定插件是否有问题,或者我只是没有正确输入电话号码,因为每次我尝试注册我的电话号码时,我都会在chrome inspect页面上看到以下错误
registerPhone错误未知验证码错误实例:com.google.firebase.FirebaseException
现在是代码
Login.ts
import {Component, ViewChild, OnInit} from '@angular/core';
import {IonicPage, NavController, AlertController} from 'ionic-angular';
import {AngularFireAuth} from '@angular/fire/auth';
import {Firebase} from '@ionic-native/firebase';
import * as firebase from 'firebase/app';
/**
* Generated class for the LoginPage page.
*
* See https://ionicframework.com/docs/components/#navigation for more info on
* Ionic pages and navigation.
*/
@IonicPage()
@Component({
selector: 'page-login',
templateUrl: 'login.html',
})
export class LoginPage implements OnInit {
@ViewChild('phoneNumber') phoneNumber;
constructor(
private navCtrl: NavController,
private fireAuth: AngularFireAuth,
private alertCtrl: AlertController,
private fire: Firebase,
) {
}
ngOnInit() {
console.log('LoginPage ngOnInit');
this.fireAuth.authState.subscribe(auth => {
if (!auth) {
return;
}
auth.getIdToken()
.then((token: string) => {
console.log('LoginPage getIdToken token', token);
if (token) {
this.doLogin();
}
});
});
}
// tslint:disable-next-line
private registerPhone(): void {
console.log('registerPhone');
const phone = '+55' + this.phoneNumber.value;
console.log('registerPhone phone', phone);
this.fire.verifyPhoneNumber(phone, 120)
.then((res) => {
const {verificationId} = res;
console.log('registerPhone verificationId', verificationId);
this.showPrompt(verificationId);
})
.catch(err => {
console.log('registerPhone err', err);
})
}
private async verifyCode(code: string, verificationId: string) {
try {
const credential = await firebase.auth.PhoneAuthProvider.credential(verificationId, code);
await firebase.auth().signInWithCredential(credential)
.then(() => {
this.doLogin();
})
.catch(err => {
console.error('LoginPage verifyCode signInWithCredential err', err);
})
} catch (err) {
console.error('LoginPage verifyCode err', err);
}
}
private showPrompt(verificationId: string) {
let promptCode = this.alertCtrl.create({
title: 'Verify',
message: 'Type code that was received via SMS',
inputs: [
{
name: 'code',
placeholder: 'Code'
},
],
buttons: [
{
text: 'Cancel',
handler: data => {
return;
}
},
{
text: 'Verify',
handler: data => {
this.verifyCode(data.code, verificationId);
}
}
]
});
promptCode.present();
}
private doLogin(): void {
this.navCtrl.setRoot('HomePage');
}
}
Login.html
<!--
Generated template for the LoginPage page.
See http://ionicframework.com/docs/components/#navigation for more info on
Ionic pages and navigation.
-->
<ion-header>
<ion-navbar>
<ion-title>Login</ion-title>
</ion-navbar>
</ion-header>
<ion-content padding>
<div class="login-verify" id="recaptcha-container"></div>
<ion-list>
<ion-item>
<ion-label>+55</ion-label>
<ion-input #phoneNumber type="tel" maxlength="11"></ion-input>
</ion-item>
</ion-list>
</ion-content>
<ion-footer class="login-footer">
<button full ion-button class="login-btn" (click)="registerPhone()">Go</button>
</ion-footer>
以下是输出:https://imgur.com/a/OjTdZVB
每次尝试,我都会:+ CC接线员号码,电话号码,总共11个数字。