AWS Cognito软件令牌MFA在第一次使用后,意外地恢复为所有未来登录的短信MFA。
创始人
2024-11-15 07:00:24
0

要解决这个问题,可以使用AWS SDK来创建一个Lambda函数,该函数会在用户首次使用MFA软令牌时,将其配置为强制性的MFA方式。以下是一个使用Python和Boto3库的示例代码:

import boto3

def lambda_handler(event, context):

    # 初始化Cognito身份提供者客户端
    cognito = boto3.client('cognito-idp')
    
    # 从Lambda事件中获取用户池ID和用户名
    userpool_id = event['userPoolId']
    username = event['userName']
    
    try:
        # 获取用户信息
        response = cognito.admin_get_user(
            UserPoolId=userpool_id,
            Username=username
        )
        
        # 检查用户是否已配置软令牌MFA
        mfa_enabled = False
        for attr in response['UserAttributes']:
            if attr['Name'] == 'phone_number_verified':
                mfa_enabled = attr['Value'] == 'true'
                break
        
        # 如果软令牌MFA已启用,则配置为强制性
        if mfa_enabled:
            response = cognito.admin_set_user_mfa_preference(
                UserPoolId=userpool_id,
                Username=username,
                SMSMfaSettings={
                    'Enabled': True,
                    'PreferredMfa': True
                }
            )
            print("MFA设置已更新")
        
    except Exception as e:
        print("发生错误: {}".format(e))
    
    # 返回Lambda函数的响应
    return {
        'statusCode': 200,
        'body': 'MFA设置已更新'
    }

你可以创建一个AWS Lambda函数,将上述代码粘贴到函数编辑器中,并将触发器配置为适当的事件,例如Cognito的用户池触发器。当用户首次使用软令牌MFA时,Lambda函数将被触发,并将其配置为强制性MFA方式。

请注意,此示例代码仅设置了SMS MFA作为首选MFA方式。如果要使用其他MFA方式,如TOTP软令牌或硬件MFA设备,你需要相应地更改代码中的MFA设置参数。

此外,你还需要在Lambda函数的权限配置中,给予它执行Cognito API操作所需的适当权限。

希望这可以帮助到你解决问题!

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...