aws cognito用户获取id令牌android

时间:2018-02-28 14:33:33

标签: android amazon-web-services session aws-cognito

我试图在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网关。

2 个答案:

答案 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();
        }
      });
    });
  }