我试图在Android中为aws cognito获取当前登录用户的id令牌。
我找到了这个例子: session.getIdToken()。getJWTToken() 其中session是CognitoUserSession对象
我似乎无法找到一种方法来在登录呼叫完成后获得当前的认知能力。
我使用了notes教程中的默认身份验证器活动: https://docs.aws.amazon.com/aws-mobile/latest/developerguide/tutorial-android-aws-mobile-notes-auth.html
它表示令牌存储在共享首选项中,但我无法弄清楚如何在将来的活动中检索它们,以便我可以使用id令牌调用api网关。
答案 0 :(得分:1)
当令牌未/将过期时,AWS Android SDK将在没有网络呼叫的情况下返回JWT令牌。
可以使用CognitoIdentityProviderClientConfig.setRefreshThreshold(long)
方法设置刷新令牌的阈值。
如果您对如何自己检索令牌感到好奇,那么可以在readCachedTokens()
方法中找到代码
https://github.com/aws/aws-sdk-android/blob/master/aws-android-sdk-cognitoidentityprovider/src/main/java/com/amazonaws/mobileconnectors/cognitoidentityprovider/CognitoUser.java#L2116
答案 1 :(得分:0)
由于还没有人回答,这可能会帮助你,要知道这是JS代码:
这是我从已登录用户接收会话的例行程序。 在此之后,我可以访问令牌。
var user_data = {
UserPoolId: AWSConfiguration.UserPoolId,
ClientId: AWSConfiguration.ClientAppId
};
var userPool = new AWSCognito.CognitoIdentityServiceProvider.CognitoUserPool(user_data);
if (userPool.getCurrentUser() != null) {
userPool.getCurrentUser().getSession(function (err, session) {
if (err) {
window.location.href = "login.html";
}
var user_params = {
IdentityPoolId: AWSConfiguration.IdPoolId,
Logins: {
'cognito-idp.eu-central-1.amazonaws.com/eu-central-1_XXX':session.idToken.jwtToken
}
};
AWS.config.credentials = new AWS.CognitoIdentityCredentials(user_params);
AWS.config.region = AWSConfiguration.region;
AWS.config.credentials.refresh((error) => {
if (error) {
console.error(error);
}
else {
user_is_authenticated();
}
});
});
}