我用安装了我的iOS应用程序。我正在使用的服务是AWS认知和AWS DynamoDB。
我在AWS DynamoDB上创建了一个私有表,默认情况下该表具有分区键userId。据我所知,AWS DynamoDB只允许userId成为identityId,例如AWSIdentityManager。
我能够通过AWSCognitoIdentityUserPool.default().currentUser()?.getSession()成功地建立一个用户会话。
我与DynamoDB一起读/写AWS identityId,通过AWSIdentityManager.default().identityId,作为userId。
但是,identityId在设备上始终保持不变,即使我已经建立了一个用户会话。
我如何从identityId获得一个专门针对AWS认知用户的AWSIdentityManager?
发布于 2018-05-23 20:57:03
编辑:
IdentityId是唯一的每个认知用户,正如我们在注释线程中共同发现的,但是它们被缓存在设备上,并且需要在注销时被清除。通过快速sdk进行清除,并:
AWSCognitoIdentityProvider.Clear()以下是我最初的回答,建议使用用户名或别名,这也是唯一的每个认知用户,但它只应用作评论讨论的参考。使用IdentityId作为dyanmodb主键代替。
结束编辑:
我建议在dynamodb表中使用用户名作为分区键。
您可以通过以下方式从AWSCognitoIdentityUser对象获取用户名
if let username = AWSCognitoIdentityUserPool.default().currentUser()?.username {
// do stuff with username
}您还可以将用户池配置为使用自定义用户名别名,以允许用户通过电子邮件和/或电话号码登录。在这种情况下,电子邮件和/或电话号码也是唯一的,如果您愿意的话,可以将其中任何一个用作dynamodb表中的唯一分区键。这是一个别名概述在干邑。
https://stackoverflow.com/questions/50495962
复制相似问题