实现社交登录

PWA Kit 开箱即用,可选择为购物者使用社交登录。在您的 Progressive Web App (PWA) Kit 网站中包括该功能,以改善购物者体验。通过社交媒体登录,购物者可以使用他们的社交媒体网络帐户快速登录您的网站并创建个人概况。

我们的 演示站点 显示了社交登录的默认实现。

若要为 PWA Kit 站点启用和配置社交登录,请按照本指南中的步骤作。在本指南中,我们使用一个具有 URL 的示例网店: https://www.example.com。替换 example.com 为您的域名。

混合网店不支持社交登录。

PWA Kit 支持“ 支持的身份提供程序”下列出的标识提供者 (IdP)。

如果您满足 先决条件 ,则默认情况下,Google 和 Apple 社交登录在 Retail React App 中可用。

要使用社交登录:

  • 使用可组合型网店和 Retail React App 版本 6.0 或更高版本构建站点。
  • 要添加您选择的 IdP,请完成 注册身份提供商中的步骤。
  • 配置购物者登录和 API 访问 (SLAS) 客户端。在客户端的重定向 URI 字段中,输入要在社交登录流中使用的重定向 URI。默认情况下,PWA Kit 用作 /social-callback 路径。例如,如果您的域是 example.com ,请输入: https://www.example.com/social-callback。替换 example.com 为您的实际域。

a.更新template-retail-react-app/config/default.js

若要在 PWA Kit 项目中配置社交登录,请按此示例所示进行更新 template-retail-react-app/config/default.js

确保在 PWA Kit 项目中配置的重定向 URI 路径与 SLAS 客户端中配置的路径匹配。SLAS 客户端可以对完整的 URI 使用通配符,但路径必须完全匹配。

b.可选:使用环境变量设置重定向 URI

社交登录环境变量的值将覆盖您在 中添加 template-retail-react-app/config/default.js的任何值。

(可选)可以使用环境变量而不是 template-retail-react-app/config/default.js来设置重定向 URI。用于 template-retail-react-app/config/default.js 启用社交登录并设置 IdP。配置此环境变量以设置重定向 URI。

SOCIAL_LOGIN_REDIRECT_URI

参阅环境变量

默认情况下,PWA Kit 会在文件的 template-retail-react-app/app/components/social-login/index.jsx 组件中 SocialLogin 导入和配置 Google 和 Apple 社交登录的图标。在您的站点上,您可以包含其他 受支持的 IdP 的图标。为此,请完成以下步骤。

a.将图标 SocialLogin 导入组件

在此示例中,我们将 Facebook 图标导入到组件中 SocialLogin

b.扩展 IDP_CONFIG 对象

IDP_CONFIG 使用组件中的 SocialLogin 对象来显示其他社交登录的按钮,每个按钮都有各自的图标和本地化的消息。

在此示例中,我们添加 Facebook 的配置。确保每个 IdP 密钥都与您选择的 IdP 的小写名称匹配。

  • 遵循最佳安全实践来保护购物者账户。例如:
  • 跟踪购物者对身份验证选项的使用情况并有效地诊断问题。例如,使用 Log Center 访问来自 Managed Runtime (MRT) 和 B2C Commerce 实例的日志。
  • 在 Shopper Login and API Access Service (SLAS) 中合并购物者资料 ,以确保同时拥有 B2C Commerce 身份和第三方 IdP 的购物者可以无缝登录,而无需创建重复账户。
  • 如果这两个配置文件在您配置 loginMergeClaims 之前和购物者登录您的站点之前都存在,则不会执行合并。账户无法追溯合并。
  • 合并购物者资料指南中的步骤适用于其 B2C Commerce 个人资料和第三方 IdP 具有相同登录 ID 的购物者。

有关合并配置文件和支持的用例的更多详细信息,请参阅 合并购物者配置文件

本节针对可能遇到的与社交登录相关的一些常见错误提供建议的解决方案。

潜在原因: 社交登录配置不正确。

建议的解决方案: 确保在 PWA Kit 项目中配置的重定向 URI 路径与 SLAS 客户端中配置的路径匹配。请参阅 配置社交登录

潜在原因: 购物者拥有 B2C Commerce 和第三方 IdP 的单独配置文件。

建议的解决方案: 按照 合并购物者资料 中的步骤合并在 B2C Commerce 和第三方 IdP 注册的购物者的记录。