热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在React中使用firebase向谷歌认证?

如何在React中使用firebase向谷歌认证?原文:

如何在 React 中使用 firebase 向谷歌认证?

原文:https://www . geeksforgeeks . org/如何使用 firebase-in-react 向 google 进行身份验证/

下面的方法涵盖了如何在 react 中使用 firebase 向 Google 进行身份验证。我们已经使用火焰基地模块来实现所以。

创建反应应用程序并安装模块:

步骤 1: 使用以下命令创建一个反应缅甸:

npx create-react-app myapp

步骤 2: 在创建项目文件夹(即 myapp )后,使用以下命令将移动到该文件夹:

cd myapp

项目结构:我们的项目结构会是这样的。

步骤 3: 创建 ReactJS 应用程序后,使用以下命令安装 firebase 模块:

npm install firebase@8.3.1 --save

第 4 步:转到你的 firebase 仪表盘,创建一个新项目并复制你的凭证。

const firebaseCOnfig= {
apiKey: "your api key",
authDomain: "your credentials",
projectId: "your credentials",
storageBucket: "your credentials",
messagingSenderId: "your credentials",
appId: "your credentials"
};

第 5 步:通过用下面的代码创建 Firebase.js 文件,将 Firebase 初始化到您的项目中。

火库. js

import firebase from 'firebase';
const firebaseCOnfig= {
    // Your credentials
};
firebase.initializeApp(firebaseConfig);
var auth = firebase.auth();
var provider = new firebase.auth.GoogleAuthProvider(); 
export {auth , provider};

第六步:进入你的 firebase 仪表盘,启用谷歌登录方法,如下图所示。

步骤 7: 现在使用以下命令安装 npm 包,即反应-火焰-钩子。

npm i react-firebase-hooks

这个包帮助我们倾听用户的当前状态。

第 8 步:创建两个文件,即 login.jsmain.js ,代码如下。

log in . js-登入

import React from 'react';
import {auth , provider}  from './firebase.js';
const Login = () => {
    // Sign in with google
    const signin = () => {
        auth.signInWithPopup(provider).catch(alert);
    }
    return (
        


            

                
            

        

    );
}
export default Login;

Main.js

import React from 'react';
import {auth} from './firebase';
const Mainpage = () => {
    // Signout function
    const logout = () => {
        auth.signOut();
    }
    return (
        


            Welcome
            {
                auth.currentUser.email
            }
            
        

    );
}
export default Mainpage;

第 8 步:最后导入 App.js 文件中所有需要的文件,如下图所示。

App.js

java 描述语言

import React from 'react';
import {auth} from './firebase';
import {useAuthState} from 'react-firebase-hooks/auth';
import Login from './login';
import Mainpage from './main';
function App() {
  const [user] = useAuthState(auth);
  return (
    user ? :
  );
}
export default App;

运行应用程序的步骤:从项目的根目录使用以下命令运行应用程序:

npm start

输出:现在打开浏览器,转到http://localhost:3000/,会看到如下输出:


推荐阅读
  • 本文详细介绍了如何在ReactJS项目中集成Onsen-UI的ActionSheetButton组件,并通过具体示例展示了其使用方法及效果。 ... [详细]
  • 本文总结了在使用React Native开发过程中遇到的一些常见问题及其解决方法,包括配置错误、依赖问题和特定组件的使用技巧。 ... [详细]
  • Windows 系统中 Flutter 与 IntelliJ IDEA 的环境配置指南
    本指南详细介绍了如何在 Windows 操作系统上设置 Flutter 开发环境,并集成至 IntelliJ IDEA 中,适合初学者及专业人士参考。 ... [详细]
  • 深入理解SAP Fiori及其核心概念
    本文详细介绍了SAP Fiori的基本概念、发展历程、核心特性、应用类型、运行环境以及开发工具等,旨在帮助读者全面了解SAP Fiori的技术框架和应用场景。 ... [详细]
  • Node.js模块化的优势及实践
    本文探讨Node.js模块化的重要性和具体实现方式,包括其带来的代码复用性增强、可维护性提升、以及如何有效避免命名冲突等问题。 ... [详细]
  • 本文将详细介绍如何配置并整合MVP架构、Retrofit网络请求库、Dagger2依赖注入框架以及RxAndroid响应式编程库,构建高效、模块化的Android应用。 ... [详细]
  • 本文详细探讨了在Python开发中遇到的ImportError: 无法找到名为Crypto.Cipher的模块的问题,并提供了多种解决方案,包括环境配置、库安装和代码调整等方法。 ... [详细]
  • Android 5 及以上版本中使用存储访问框架(SAF)实现 SD 卡写入权限的方法
    本文探讨了在 Android 5 及更高版本中通过存储访问框架(Storage Access Framework, SAF)实现对 SD 卡文件的写入与重命名操作。文章分析了 SAF 的工作原理,并提供了一个示例应用的代码实现,展示了如何正确获取并使用用户授予的写入权限。 ... [详细]
  • 教程:如何打造令人印象深刻的GitHub个人主页Readme
    本文将指导您如何创建一个既专业又个性化的GitHub个人主页Readme,通过添加统计数据、常用语言和最近活动等元素,让您的主页更加吸引人。 ... [详细]
  • 本文探讨了如何利用 Application 对象在 PHP 应用程序中共享数据,特别是在多用户环境中保持数据的一致性和安全性。文章还介绍了 Application 对象的基本结构、方法和事件,并提供了实际应用示例。 ... [详细]
  • 本文探讨了在Vue项目中使用BetterScroll时,由于网络请求慢导致滚动区域无法正常滑动的原因及解决方案。重点介绍了通过监听图片加载事件并调用refresh方法来解决这一问题的方法。 ... [详细]
  • ANSI最全介绍linux终端字体改变颜色等ANSI转义序列维基百科,自由的百科全书由于国内不能访问wiki而且国内关于ANSI的介绍都是简短的不能达到,不够完整所以转wiki到此 ... [详细]
  • 本文提供了详细的指导,帮助开发者了解如何使用PHP插件进行网站内容的翻译,特别是针对WordPress插件和主题的汉化及多语言支持。 ... [详细]
  • 本文介绍了FTP(文件传输协议)的基础知识,包括其定义、如何通过TCP建立控制和数据连接,以及主动模式与被动模式的区别。FTP作为一种重要的文件传输协议,在互联网数据交换中扮演着关键角色。 ... [详细]
  • 前端技术分享——利用Canvas绘制鼠标轨迹
    作为一名前端开发者,我已经积累了Vue、React、正则表达式、算法以及小程序等方面的技能,但Canvas一直是我的盲区。因此,我在2018年为自己设定了一个新的学习目标:掌握Canvas,特别是如何使用它来创建CSS3难以实现的动态效果。 ... [详细]
author-avatar
我病态见不得你跟别人恩爱
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有