在 Express.js 中使用 Passport.js 实现 Google 登录功能

简介

在现代 Web 应用中实现用户登录和认证是很常见的需求,为了简化和标准化这个过程,已经有很多流行的第三方认证服务。其中,Google 是被广泛使用和信赖的服务之一,因为它提供了强大的用户管理和数据隐私保护机制。在 Express.js 中使用 Passport.js,一个非常流行的 Node.js 认证中间件,可以轻松实现 Google 登录功能。

前置知识

在阅读本文之前,你需要:

  • 熟悉 JavaScript 和 Node.js
  • 熟悉 Express.js 框架
  • 了解 OAuth 2.0 认证流程和授权码模式

步骤

1. 配置 Google APIs

https://console.developers.google.com/ 创建一个 Google Cloud Platform 项目,或者在已有项目中添加 Google 登录 API。然后在 API 管理页面中创建一个 OAuth 客户端 ID,选择 Web 应用类型,并填写正确的重定向 URI。例如,如果你本地的 Express.js 服务器监听在 http://localhost:3000 上,那么重定向 URI 应该设置为 http://localhost:3000/auth/google/callback。记住生成的客户端 ID 和客户端密钥。

2. 安装依赖

使用 npm 命令行安装 express、passport、passport-google-oauth20 和 express-session 模块。如果你的 Web 应用已有这些依赖,则可以跳过此步骤。

--- ------- ------- -------- ----------------------- ---------------

3. 配置 Passport.js

在 Express.js 应用中添加 passport 和 express-session 中间件,并使用 passport 中间件进行初始化。然后添加两个路由:一个用于重定向到 Google 登录授权页面,另一个用于处理 Google 返回的授权码和访问令牌。在调用 passport.authenticate('google') 方法时,将自动生成一个 URL,用于发送给前端,让用户点击后跳转到授权页面。Google 授权是一个异步的过程,需要等待用户登录和同意授权。回调处理函数 passport.authenticate('google', { failureRedirect: '/login' }) 将在 Google 返回授权码后被调用。此时要从 Google 获取用户个人资料信息,并将其保存在 session 中,以便在后续请求中进行身份验证。

----- ------- - -------------------
----- -------- - --------------------
----- -------------- - --------------------------------------------
----- ------- - ---------------------------

----- --- - ----------
----------------- ------- --------- ----- ------- ------ ------------------ ----- ----
-------------------------------
----------------------------

---------------- ----------------
    --------- -----------------
    ------------- ---------------------
    ------------ ------------------------
  --
  --------------------- ------------- -------- --- -
    -------- ---------
  -
---

------------------------------------- ----- -
  ---------- ------
---

--------------------------------------- ----- -
  ---------- ------
---

-----------------------
  ------------------------------- - ------ ----------- ----

--------------------------------
  ------------------------------- - ---------------- -------- ---
  ------------- ---- -
    -- ---------- --------------- -------- -----
    ------------------
  ---

4. 实现用户认证

为了实现用户认证,我们需要对 Express.js 的路由进行保护。在进入受保护的路由之前,检查是否有针对 Google 身份验证保存在 session 中的用户信息,如果有,则允许访问,否则跳转到登录页面。在上述示例代码中,只需添加一个名为 ensureAuthenticated 的中间件来执行该检查。该中间件可以在需要加入身份验证的路由中使用。

-------- ------------------------ ---- ----- -
  -- ----------------------- -
    ------ -------
  -

  -----------------------
-

现在,你可以轻松地实现 Google 登录和用户认证功能。在实践过程中,你还可以使用其他的 OAuth 2.0 认证策略和数据存储方案,以满足更具体和复杂的需求。该示例代码只是一个演示,建议在实际应用中进行更适当的安全性和错误处理措施。

总结

在本文中,我们学习了如何在 Express.js 中使用 Passport.js 实现 Google 登录功能。Passport.js 可以帮助我们简化认证流程,方便地与 Google API 集成,提供了可扩展和灵活的认证策略和存储方案。Google 登录作为一种安全性和便利性兼备的第三方认证服务,可以将用户管理和隐私保护任务转交给 Google,从而减轻我们的负担并提高了可信度。希望本文的内容对你学习和实践 Web 开发有所帮助。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/64c487f583d39b4881808629


猜你喜欢

  • 了解 ECMAScript 2017 中的对象解构

    在 ECMAScript 2017 中,对象解构 (Object Destructuring) 成为了许多前端开发人员广泛使用的一种技术。它使得开发人员能够在代码中更高效、更清晰地使用对象的属性和方法...

    1 年前
  • React SPA 应用优化中的 Tips 分享

    在前端开发中,应用的性能优化是一项至关重要的工作。特别是在 React 单页应用中,React 组件的多重嵌套,以及组件的频繁渲染,可能导致应用的性能下降。本文将详细介绍 React SPA 应用优化...

    1 年前
  • Material Design 中 DrawerLayout 导航栏使用 Tips

    介绍 Material Design 是一种设计语言, 被广泛用于安卓应用、网页和其他数字媒体的设计。作为前端工程师必须熟悉的一个重要组件,DrawerLayout 导航栏在 Material Des...

    1 年前
  • Redux 与服务端通信的最佳实践

    随着移动互联网的发展,前端应用的复杂性逐渐增加,因此需要对数据流进行更好的管理和维护,来确保应用的稳定运行。在前端领域,Redux 是一种很受欢迎的状态管理库,它能够帮助我们管理应用中的数据流,同时它...

    1 年前
  • 如何进行无障碍程序的开发

    在现代社会,数字化已经贯穿人们的生活的方方面面,其中互联网和智能手机等设备成为人们日常生活不可或缺的组成部分。但是,在数字化的同时,也有一部分人仍然有着特殊的需求,这就需要我们重视无障碍开发的重要性。

    1 年前
  • webpack-dev-middleware 详解

    webpack-dev-middleware 是一个可以结合 Express 或者 Koa 使用的中间件,它可以将 Webpack 打包出来的资源直接在内存中读取和发送到浏览器,而不需要每次都写入到磁...

    1 年前
  • 使用 Chai 进行链式断言的技巧

    在前端开发中,我们经常需要进行测试以保证代码的稳定性和正确性。而一个好的测试工具是非常重要的。Chai 是一个流行的测试工具,它提供了丰富的断言库,可以帮助我们测试各种不同类型的数据。

    1 年前
  • RxJS 的协程模型应用

    前言 RxJS 是一个强大的前端类库,它主要用于响应式编程。在 RxJS 中,一个被观察者可以发出任何数量的值,而一个观察者可以订阅该被观察者并处理这些值。RxJS 中的一些概念,如 Observab...

    1 年前
  • 使用 PWA 的坑及解决方案分享

    什么是 PWA? PWA (Progressive Web App) 是一种使用 modern web capabilities(现代 web 技术)来提升 web 应用程序体验的方法。

    1 年前
  • 应当注意!ES11 中新增的??空值合并运算符使用时的注意事项

    应当注意!ES11 中新增的空值合并运算符使用时的注意事项 在 ES2020 中,新增了一个空值合并运算符(??),该运算符可以用于处理空值的情况。当该运算符在表达式中使用时,如果左侧的操作数为 nu...

    1 年前
  • Fastify 框架中优秀的 ORM 解决方案推介

    在 Web 开发中,ORM(Object-Relational Mapping)是一个非常重要的概念。ORM 是一种将对象表示和数据库之间的映射关系自动化的技术,它能帮助我们更加便捷地操作数据库,从而...

    1 年前
  • ECMAScript 2019 (ES10):让对象转换成一直格式的 JSON.stringify

    ECMAScript 2019 (ES10):让对象转换成一直格式的 JSON.stringify 概述 JSON.stringify() 是一个在前端开发中非常常用的方法,它可以把一个 JavaSc...

    1 年前
  • Redis 在多进程环境中出现问题的解决方法

    在前端开发中,Redis 是一个常用的高性能的缓存和数据库系统。然而,在多进程环境中,Redis 经常会出现一些问题。本文将介绍这些问题以及如何解决它们,并提供相关示例代码。

    1 年前
  • Serverless 架构下的云端音视频处理技术实践

    随着互联网技术的发展,越来越多的应用需要处理音视频数据。然而,音视频数据处理是一项非常耗费计算资源的任务,传统的云服务架构无法满足高并发的需求。而 Serverless 架构,以其弹性伸缩和按需计费的...

    1 年前
  • 深入理解 Web Components 技术

    Web Components 技术是一种在 Web 应用开发中越来越受欢迎的技术,它提供了一种组件化开发的方式,使得前端开发变得更加高效、灵活和可维护。本文将从以下几个方面深入探讨 Web Compo...

    1 年前
  • PM2 在多核服务器上的集群应用实践

    随着互联网的不断发展,Web 应用越来越广泛,对于前端开发来说,如何使 Web 服务稳定、高效地运行是一项重要任务。在这个任务中,PM2 可以起到很大的帮助。 PM2 是什么 PM2 是一个现代的 N...

    1 年前
  • 如何为自定义元素添加事件处理程序

    如何为自定义元素添加事件处理程序 在前端开发中,有时需要使用自定义元素来完成特定的功能或者样式展示。但是,自定义元素不同于普通的 HTML 元素,它们没有一些默认的事件处理程序。

    1 年前
  • 浅谈 Promise 中的 catch 和 reject 区别

    #浅谈 Promise 中的 catch 和 reject 区别 ##前言 Promise 是 JavaScript 中非常重要的概念之一,用来封装异步操作并返回结果。

    1 年前
  • Koa 框架中设置路由过滤器的方法

    Koa 是 Node.js 的一个 Web 框架,它的设计基于中间件(middleware),这让开发者可以通过简单的堆叠中间件来完成复杂的功能。在使用 Koa 框架进行开发时,路由过滤器是一个很常见...

    1 年前
  • CSS Flexbox 布局与 Grid 布局之间的对比

    在前端开发中,我们会经常使用到布局,而布局的实现有多种方式,其中 CSS 的 Flexbox 和 Grid 是目前较为常用的两种布局方法。那么在具体使用中,它们有哪些区别和特点呢?本文将深入比较 Fl...

    1 年前

相关推荐

    暂无文章