AWS Cognito Workflow:使用主用户名

时间:2017-02-28 18:08:11

标签: amazon-web-services aws-cognito

因此,我试图了解AWS Cognito,但我遇到了一些障碍。

所以,现在我可以注册一个帐户,并验证并登录。简单就够了。边缘情况是我的墙壁。

这是我到目前为止的信息:

这就是我的优势所在。

如果用户注册,但会立即验证:

  • 他们被叫走了
  • 也许应用程序崩溃
  • 他们失去了连接
  • 他们的电池耗尽
  • 他们强行退出
  • app被意外删除。

在他们看来,他们已注册但未验证他们的帐户。在这一点上,它实际上没有办法验证他们认为他们注册的帐户。我猜它可以通过消息传递来解决:

"警告在您验证电子邮件地址之前,系统不会创建您的帐户。"或类似的规定。无论如何...

  • 他们无法尝试登录,因为他们无法知道随机分配为username的UUID。
  • 即使不是这样,他们也提供了电子邮件地址作为用户名。根据用户的POV,他们不知道他们username甚至可能是什么,因为他们只输入了他们的电子邮件地址。
  • 他们最希望的是尝试再次注册。 (假设他们阅读了上面的验证警告)在这种情况下,现在Cognito可能已经放弃了堆积的未经证实的帐户。

"堆积"可能是一个过于强烈的短语,这可能是一个非常边缘的案例。

现在好的方面是,因为他们没有经过验证"他们email他们可以使用相同的email地址重新注册,因为email没有得到唯一约束,直到verified为止。如果有人试图验证已经过验证的地址,则会获得AliasExistsException。这实际上提出了一个我刚刚测试过的有趣点。

我可以使用电子邮件地址注册,然后验证该电子邮件地址,以便帐户得到确认。然后,我可以右转并使用相同的电子邮件地址注册,并且在尝试使用重复的电子邮件地址验证该帐户之前,我不会收到正式的AWS错误。没有任何方法可以提前发现此错误?我想,开发人员希望在预注册触发器中编写验证服务:

  

当用户提交注册信息时,会调用此触发器,允许您执行自定义验证以接受或拒绝注册请求。

总结一下,并重申一下问题:

似乎必需,实际上,当使用带有Cognito的电子邮件地址时,需要预先注册Lambda才能确保使用电子邮件的帐户自已存在以来不存在在进行验证尝试之前,不会处理AWS异常。

我的假设在这里是否正确?通过必需,我认为让用户知道电子邮件地址尽快无法使用是非常合理的。例如:

John Doe : jdoe@gmail.com
Jane Doe : jdoe@gmail.com

1 个答案:

答案 0 :(得分:0)

您是正确的。 另一种解决方案是创建一个lambda(不由preSignUp触发),并在用户完成在电子邮件字段中的键入时调用它。甚至在发送注册事件之前都会收到“此电子邮件已被使用”或“此电子邮件可用”的响应。

请参阅问题的第一部分。如果用户没有立即验证其电子邮件。您可能意味着通过代码进行确认。我更喜欢使用发送到电子邮件的链接进行确认,这样可以避免此问题。