React + AWS Cognito:电子邮件身份验证设置指南(第二部分)

在上一篇文章中,我们处理了 aws 端的所有内容;现在让我们深入研究 react 来设置我们的代码。

aws 提供了 npm 包 @aws-sdk/client-cognito-identity-provider,其中包含以下功能:

使用电子邮件和密码创建帐户通过 aws 发送的代码验证电子邮件使用电子邮件和密码登录

React + AWS Cognito:电子邮件身份验证设置指南(第二部分)

查看演示页面亲自尝试一下,并随时查看 github 存储库中的代码。

报名

第一步是注册

import { signupcommand } from "@aws-sdk/client-cognito-identity-provider";const aws_client_id = "replace_with_your_aws_client_id";const aws_region = "replace_with_your_aws_region";const cognitoclient = new cognitoidentityproviderclient({  region: aws_region,});export const signup = async (email: string, password: string) => {  const params = {    clientid: aws_client_id,    username: email,    password: password,    userattributes: [      {        name: "email",        value: email,      },    ],  };  const command = new signupcommand(params);  try {    await cognitoclient.send(command);  } catch (error) {    throw error;  }};

请注意 aws_client_id 是如何必需的,并且此帮助函数接受电子邮件和密码。在演示中,这两个值均由用户在表单中输入,然后 ui 调用此方法并传递这些值。

如果出现错误,则会抛出异常,并且 ui 会进行相应处理。

确认

注意:在测试过程中,表单中使用的任何电子邮件都必须首先经过验证。这在生产中是不必要的。

当 signupcommand 运行时,aws 会注册帐户并通过电子邮件发送验证码,因此下一步是检查收件箱并复制代码。

import { confirmsignupcommand } from "@aws-sdk/client-cognito-identity-provider";const aws_client_id = "replace_with_your_aws_client_id";const aws_region = "replace_with_your_aws_region";const cognitoclient = new cognitoidentityproviderclient({  region: aws_region,});export const confirmsignup = async (username: string, code: string) => {  const params = {    clientid: aws_client_id,    username: username,    confirmationcode: code,  };  const command = new confirmsignupcommand(params);  try {    await cognitoclient.send(command);  } catch (error) {    throw error;  }};

请注意,confirmsignupcommand 需要您的 aws clientid、用户名(电子邮件)以及发送到电子邮件的确认代码。

登入

如果confirmsignupcommand成功完成,则帐户应该已准备好登录。

import {  AuthFlowType,  SignUpCommand,} from "@aws-sdk/client-cognito-identity-provider";const AWS_CLIENT_ID = "REPLACE_WITH_YOUR_AWS_CLIENT_ID";const AWS_REGION = "REPLACE_WITH_YOUR_AWS_REGION";const cognitoClient = new CognitoIdentityProviderClient({  region: AWS_REGION,});export const signIn = async (username: string, password: string) => {  const params = {    AuthFlow: AuthFlowType.USER_PASSWORD_AUTH,    ClientId: AWS_CLIENT_ID,    AuthParameters: {      USERNAME: username,      PASSWORD: password,    },  };  const command = new InitiateAuthCommand(params);  let AuthenticationResult;  try {    const response = await cognitoClient.send(command);    AuthenticationResult = response.AuthenticationResult;  } catch (error) {    throw error;  }  if (!AuthenticationResult) {    return;  }  sessionStorage.setItem("idToken", AuthenticationResult.IdToken || "");  sessionStorage.setItem("accessToken", AuthenticationResult.AccessToken || "");  sessionStorage.setItem(    "refreshToken",    AuthenticationResult.RefreshToken || ""  );  return AuthenticationResult;};

在 initiateauthcommand 中,aws 需要用户通过表单提供的 clientid、用户名(电子邮件)和密码。如果邮箱已通过验证,则登录成功。

此外,一些值存储在 sessionstorage 中以供将来使用。

结论

查看演示并探索代码库。

cognito 相对容易设置但功能强大。它处理创建、验证和验证帐户等基本操作。虽然可以为此构建自己的服务,但需要付出巨大的努力来正确实施和维护。

启动项目时,云服务具有减轻这些责任的优势,因此您可以专注于核心业务逻辑,即使它引入了一些依赖性。

以上就是React + AWS Cognito:电子邮件身份验证设置指南(第二部分)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1497253.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
如何解决html、body元的高度问题
上一篇 2026年5月10日 11:00:57
如何在用户界面中管理多对多关系:以用户与场地为例的教程
下一篇 2026年5月10日 11:01:02

相关推荐

  • clion的安装与配置教程

    CLion是一款由JetBrains开发的C/C++ IDE。安装步骤包括:下载并安装CLion、安装CMake、选择工具链。配置步骤包括:导入项目、编译和运行、调试、代码格式化、添加插件。CLion支持多种功能,包括CMake构建、工具链选择、代码格式化、调试和插件扩展。 CLion 安装与配置教…

    2026年5月10日
    000
  • HTML语义化:单列数据展示的最佳实践与替代方案

    HTML语义化:单列数据展示的最佳实践与替代方案HTML语义化:单列数据展示的最佳实践与替代方案HTML语义化:单列数据展示的最佳实践与替代方案HTML语义化:单列数据展示的最佳实践与替代方案

    本文探讨了将两列表格数据转换为单列、交替标题/内容格式时可能遇到的语义化和可访问性问题。它详细解释了html ` ` 元素作用域的局限性,并提出了多种符合语义化标准的替代方案,包括使用定义列表(“)、语义化标题(“ 标签)结合段落(` `),以及在特定场景下谨慎使用嵌套表格,…

    2026年5月10日 用户投稿
    000
  • C++如何使用智能指针与容器结合管理内存

    在C++中,应优先使用智能指针管理容器中的动态对象,以避免内存泄漏和悬空指针。std::unique_ptr适用于独占所有权场景,性能高且无引用计数,适合std::vector等线性容器存储多态对象;而std::shared_ptr用于共享所有权,通过引用计数管理生命周期,适用于std::map等需…

    2026年5月10日
    000
  • 九天算力平台任务:本地电脑关机后,计算任务还会继续运行吗?

    九天算力平台:本地电脑关闭后任务运行状态详解 使用九天算力平台进行AI训练时,许多用户关心一个问题:本地电脑关机后,平台上的计算任务能否继续运行? 部分用户反馈,关闭VS Code后,任务似乎停止,需要重新启动,这与预期中的远程服务器持续运行不符。 虽然平台后台显示计算时间仍在继续(用户截图所示),…

    2026年5月10日
    200
  • 什么是模块化HTML文件?如何查看HTML格式内容?

    什么是模块化HTML文件?如何查看HTML格式内容?什么是模块化HTML文件?如何查看HTML格式内容?什么是模块化HTML文件?如何查看HTML格式内容?什么是模块化HTML文件?如何查看HTML格式内容?

    现代前端开发倾向于模块化html,是因为它能有效解决大型项目中代码重复、维护困难和团队协作低效的问题,通过将页面拆分为独立、可复用的组件,实现高复用性、易维护性和高效协作,尤其在单页应用和微前端架构中不可或缺;1. 模块化使ui元素如导航栏、表单等可抽象为独立组件,一处修改全局生效;2. 支持组件为…

    2026年5月10日 用户投稿
    000
  • html如何建立副标题_为HTML文档添加副标题标签【标签】

    推荐使用与标签组合:主标题用,副标题用带class=”subtitle”的,语义清晰且不破坏大纲;已废弃但部分浏览器支持;ARIA可增强可访问性;CSS伪元素适合固定文本场景。 如果您希望在HTML文档中为标题添加副标题,以提供更详细的说明或补充信息,则需要使用语义化的方式组…

    2026年5月10日
    000
  • C++标记模式 运行时类型识别替代

    标记模式是一种基于类型标签在编译期实现函数分发的技术,通过定义标签类型(如tag_derived_a)并结合虚函数返回对应标签,利用if constexpr在编译期判断类型并调用相应逻辑,避免了RTTI开销,适用于嵌入式或性能敏感场景,但需手动扩展标签且灵活性低于dynamic_cast。 在C++…

    2026年5月10日
    000
  • Go语言随机数生成详解:如何获得每次运行都不同的随机数

    在Go语言中,rand 包提供了生成伪随机数的功能。然而,初学者经常遇到的一个问题是,每次运行程序时,生成的随机数序列都是相同的。这是因为 rand 包使用固定的默认种子来初始化随机数生成器。为了获得每次运行都不同的随机数,我们需要手动设置种子。 使用当前时间作为种子 最常用的方法是使用当前时间作为…

    2026年5月10日
    100
  • JavaScript中DOM元素ID与全局作用域的隐式绑定机制解析

    本文深入探讨了javascript中一个鲜为人知但实际存在的行为:html元素的id属性可能在全局作用域中创建同名变量。这种机制允许开发者在不使用this关键字或document.queryselector等方法的情况下直接访问dom元素,尤其是在类方法中,这常常导致对this关键字作用的误解。文章…

    2026年5月10日
    000
  • PHP 并发文件操作中的数据完整性保障:使用文件锁防止数据丢失

    本文旨在解决服务器端在处理高并发文件写入时可能发生的数据丢失问题。当多个请求同时尝试修改同一文件时,可能导致竞态条件。通过引入 PHP 的文件锁(`flock`)机制,可以确保文件在写入过程中被独占访问,从而有效防止数据损坏或丢失,保障数据传输和存储的原子性与一致性。 在现代 Web 应用中,客户端…

    2026年5月10日
    000
  • 如何在Python中设置Cookie?

    在python中,可以使用http.cookies模块或flask框架来设置cookie。使用flask设置cookie的步骤如下:1.创建响应对象,2.使用set_cookie方法设置cookie的名称、值和有效期。设置cookie时需考虑key、value、max_age、expires、pat…

    2026年5月10日
    000
  • Event Sourcing与聚合:优雅管理不变性,避免重复检查

    本文探讨了在事件溯源(Event Sourcing)架构中,聚合(Aggregates)如何高效且不重复地处理业务不变性(invariants)。通过整合相关命令和重新思考“无变化”场景的错误处理,可以优化聚合设计,避免代码冗余,并提升系统的健壮性和可维护性,尤其在处理外部数据更新时。 1. 聚合中…

    2026年5月10日
    000
  • 解决JavaScript下拉菜单动态数据显示问题:this上下文与数据处理详解

    本教程详细探讨了在javascript中,如何正确处理html下拉菜单(“)的`onchange`事件,以实现动态显示从外部数据源(如json文件)获取的信息。文章将重点解析`this`上下文的正确使用、如何高效获取选中的选项数据,以及如何将复杂的json对象以可读形式呈现在网页上,确保…

    2026年5月10日
    000
  • 如何在Golang中使用缓存提升性能

    答案:Golang中常用sync.Map、go-cache和Redis提升性能,分别适用于简单本地缓存、单机带过期缓存和分布式场景,需合理设置过期时间、应对穿透雪崩并保证数据一致性。 在Golang中使用缓存是提升性能的常见手段,尤其适用于频繁读取、计算成本高或数据库访问密集的场景。合理引入缓存能显…

    2026年5月10日
    000
  • Golang 文件夹遍历如何实现_Golang 目录递归与文件筛选实践

    使用filepath.Walk或os.ReadDir递归遍历目录,结合后缀、大小等条件筛选文件,filepath.Walk适用于自动深度遍历,os.ReadDir适合自定义递归逻辑,配合strings.HasSuffix或filepath.Match可实现按扩展名或通配符过滤,Glob支持简单模式匹…

    2026年5月10日
    000
  • Go语言中实现多态对象工厂模式的最佳实践

    本文探讨了在go语言中如何设计一个能够根据输入创建不同类型对象的工厂函数。针对初学者常遇到的直接返回具体类型或空接口导致编译失败的问题,文章详细阐述了通过定义并返回接口类型来解决这一挑战。这种方法利用go语言的隐式接口实现特性,有效构建出灵活且可扩展的对象工厂,从而实现多态行为。 Go语言对象工厂模…

    2026年5月10日
    000
  • 欧易交易所 OKX全球主流交易平台(官方网站)

    欧易(OKX)是一款全球领先的数字资产服务平台,为用户提供币币、杠杆、期权/交割/永续合约、DEX交易、余币宝、DeFi挖 矿、借贷等多元化的产品矩阵,覆盖超过200个国家和地区,拥有千万级用户量,致力于为全球用户提供一站式的数字资产服务。 欧易交易所官方网站入口 欧易全球官方网址是: 欧易OKX下…

    2026年5月10日
    000
  • 什么是XPath?如何定位XML节点?

    XPath是一种在XML/HTML文档中精准定位节点的语言,通过路径表达式、属性、文本内容及轴(如父、兄弟节点)实现灵活查找。它优于CSS选择器之处在于支持向上遍历、基于文本定位和复杂逻辑判断,适用于自动化测试、爬虫等场景,但需避免脆弱性、性能问题和可读性差等陷阱。编写健壮的XPath应优先使用唯一…

    2026年5月10日
    000
  • Robocorp Browser库截图超时错误解析与稳健重试策略

    Robocorp自动化过程中,使用Browser库的take_screenshot功能时,常因内部“聚焦”机制不稳定而遭遇超时错误。本文深入解析该问题,并提出一种高效且稳健的重试策略作为核心解决方案,通过代码示例详细阐述如何实现多次尝试截图,显著提升自动化脚本的可靠性,确保关键截图操作的成功执行,避…

    2026年5月10日
    000
  • 如何在Golang中解决模块冲突报错

    首先通过go mod graph分析依赖树定位冲突,如发现同一模块不同版本被引入;接着在go.mod中使用replace或require统一版本,例如replace github.com/another/pkg => github.com/another/pkg v1.1.0;然后执行go g…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信