javascript - undefined 不是对象 firebase.auth.FacebookAuthProvider.credential

标签 javascript facebook firebase react-native firebase-authentication

这是我的代码..它非常简单..只是试图让用户通过 facebook 进行身份验证,然后将其添加到 Firebase 系统! 我应该提一下,我正在使用 React Native,我确实读到过 Firebase 库的各个部分不适用于 React Native。

const auth = firebase.auth();
const provider = firebase.auth.FacebookAuthProvider;

LoginManager.logInWithReadPermissions(['public_profile'])
.then(loginResult => {

    alert("login results")
    if (loginResult.isCancelled) {
        alert('user canceled');
        return;
    }
    AccessToken.getCurrentAccessToken()
    .then(accessTokenData => {
        const credential = firebase.auth.FacebookAuthProvider.credential(accessTokenData.accessToken);
        alert("Credential: " + credential )
        return auth.signInWithCredential(credential);
    })
    .then(credData => {
        console.log(credData);
        alert("CRED data:::" + credData)
        alert(firebase)
    })
    .catch(err => {
        console.log(err);
        alert("ERROR:::" + err)
        alert(firebase)

    });
});

我真正能想到的唯一原因是 Firebase 未定义或者它没有完成初始化.. 虽然看起来是.. 也许我可以做出某种 promise 以确保它已经初始化。 (关于如何做到这一点有什么想法吗?)

虽然 firebase 似乎被初始化了..但我仔细阅读了 api 引用,并不能真正找到 .auth.FacebookAuthProvider.credential 不存在的任何原因

任何帮助都会很棒!

最佳答案

我遇到了这个完全相同的问题,并且我有一个适合我的解决方案,但我不确定它是否对你来说是一样的。

我通过一个单独的模块在一个名为 FirebaseService.js

的文件中实例化了我的 firebase 类
'use-strict';

const firebase = require('firebase');
const APP_BASE = 'https://your-unique-url.firebaseapp.com/'

const FIREBASE_CONFIG = {
    apiKey: '[super_unique]',
    authDomain: 'your-unique-url.firebaseapp.com',
    databaseURL: APP_BASE,
    storageBucket: 'your-unique-url.appspot.com',
};

export const Firebase = firebase.initializeApp(FIREBASE_CONFIG);

然后我通过导入它在我的代码中的其他地方使用它:

const { Firebase } = require ('./services/FirebaseService');

在我着手实现 facebook 登录之前,这似乎很好,那时我开始遇到同样的问题。

我不得不在尝试使用 facebook 登录的屏幕中导入 firebase。我没有使用自己的服务,而是使用了 npm 模块:

const firebase = require('firebase'); 

在那之后,我能够访问 FacebookAuthProvider.credential。我真的不确定为什么会这样,可能是我对模块的使用出了问题

关于javascript - undefined 不是对象 firebase.auth.FacebookAuthProvider.credential,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39204923/

相关文章:

reactjs - firebase_compat_app__WEBPACK_IMPORTED_MODULE_0__.default.database 不是函数

javascript - 第二个单词后换行并着色

ios - 强制 Facebook 电子邮件和 user_friends 权限

Android Facebook 开发人员无法在 "Save Changes"上为 "Sample App Settings"设置 "Android Key Hash"

android - Firestore 离线缓存

ios - 适用于 iOS 的 Google Firebase 推送通知在生产环境中不起作用

javascript - 关于方程和条件的简单 Html/JavaScript 问题

javascript - 检查 td 是否是最后可见的 td

javascript - 当json数据在数组中时,如何在div中显示json数据

facebook - 获取任何 Facebook 用户的公开个人资料内容