Firebase 身份验证在 iOS 上使用 Capacitor Ionic

Man*_*rya 3 javascript ionic-framework firebase-authentication capacitor

我正在使用 Angular-Fire 在 Ionic-Capacitor 上进行 Firebase 身份验证。它在 Web 和 Android 上运行良好,但在 IOS 上不行。

当我检查应用程序网络活动时,我意识到应用程序能够从 firebase 成功获取身份验证响应,但它无法完成异步调用。

我的app.module.ts

@NgModule({
  declarations: [AppComponent],
  entryComponents: [],
  imports: [BrowserModule, IonicModule.forRoot({mode: 'ios'}), AppRoutingModule,
    HttpClientModule,
    AngularFireModule.initializeApp(environment.firebaseConfig),
    AngularFireAuthModule,
    AngularFirestoreModule
]})
Run Code Online (Sandbox Code Playgroud)

这就是我初始化 Angular fire 的方式。

Man*_*rya 5

这是 FirebasePlugin 问题!您需要做的就是使用最新的方法初始化 AngularFire。

旧方法(错误)-

@NgModule({
  declarations: [AppComponent],
  entryComponents: [],
  imports: [BrowserModule, IonicModule.forRoot({mode: 'ios'}), AppRoutingModule,
    HttpClientModule,
    AngularFireModule.initializeApp(environment.firebaseConfig),
    AngularFireAuthModule,
    AngularFirestoreModule
]})
Run Code Online (Sandbox Code Playgroud)

工作方法(新)

import {getApp, initializeApp, provideFirebaseApp} from "@angular/fire/app";
import {getAuth, initializeAuth, provideAuth, indexedDBLocalPersistence} from "@angular/fire/auth";

@NgModule({

  imports: [
    provideFirebaseApp(() =>      initializeApp(environment.firebaseConfig)),
    provideAuth(() => {
      if (Capacitor.isNativePlatform()) {
        return initializeAuth(getApp(), {
          persistence: indexedDBLocalPersistence
        })
      } else {
        return getAuth()
      }
    })]
})
Run Code Online (Sandbox Code Playgroud)

修改初始化方法后,您需要删除 AngularFireAuth 的使用,而是像这样使用它:-

import {Auth, createUserWithEmailAndPassword, signInWithEmailAndPassword} from "@angular/fire/auth";

export class UserService {
 constructor(private auth : Auth) {

const user: any = await signInWithEmailAndPassword(this.auth,email,password);

}
Run Code Online (Sandbox Code Playgroud)

另外,您可以访问 AngularFire 的最新文档以更好地了解它。