在React Native中进行FB登录后,AWS Amplify currentAuthenticatedUser为null,但是当重新加载应用程序时,currentAuthenticatedUser返回有效用户

时间:2019-04-02 23:37:56

标签: react-native amazon-cognito aws-amplify

我正在尝试将Facebook登录信息集成到我的React Native应用中。

我已经能够成功实现Auth.signIn()方法,并且可以使用Auth.currentAuthenticatedUser()一致地检索用户。

但是,当我从Facebook登录名获取代码后使用Auth.currentAuthenticatedUser()时,它将返回null。

此外,当我重新加载应用程序时,Auth.currentAuthenticatedUser()将按预期返回用户。

我不明白为什么在创建带有令牌的用户会话之后,它无法识别出我拥有经过身份验证的用户。

这是我的代码:

getTokenbyCode = async (code) => {
      const details = {
        grant_type: 'authorization_code',
        code,
        client_id: userPool.clientId,
        redirect_uri: AuthSession.getRedirectUrl()
      }
      const formBody = Object.keys(details)
        .map(
          key => `${encodeURIComponent(key)}=${encodeURIComponent(details[key])}`
        )
        .join("&");

      await fetch(
        tokenURL,
        {
          method: "POST",
          headers: {
            'Content-type': 'application/x-www-form-urlencoded;charset=UTF-8'
          },
          body: formBody
        }
      )
        .then(async (res) => {
          let tokenRequestJson = await res.json();
          const IdToken = new CognitoIdToken({ IdToken: tokenRequestJson.id_token });
          const AccessToken = new CognitoAccessToken({ AccessToken: tokenRequestJson.access_token });
          const RefreshToken = new CognitoRefreshToken({ RefreshToken: tokenRequestJson.refresh_token })
          try {
            let userSession = new CognitoUserSession({ IdToken, AccessToken, RefreshToken });
            const userData = {
              Username: userSession.idToken.payload.email,
              Pool: userPool
            };

            cognitoUser = new CognitoUser(userData);
            cognitoUser.setSignInUserSession(userSession);
            cognitoUser.getSession(async (err, session) => { // You must run this to verify that session (internally)
              if (session.isValid()) {

                // EVERYTHING WORKS UP TO HERE <!---------------->

                let cognitoUser = await Auth.currentAuthenticatedUser()
                this.setState({user: cognitoUser})

                this.props.navigation.navigate('AuthLoading', {user: cognitoUser})
              } else {
                console.log('session is not valid: ', session);
              }
            })
          }
          catch (FBSignInError) {
            console.log('FBSignInError: ', FBSignInError)
          }
        })
        .catch(error => {
          console.log('error: ', error);
        });
    }

1 个答案:

答案 0 :(得分:0)

我想出了这一点,但只能靠蛮力,所以如果有人想告诉我为什么这样做有效,我很高兴听到它。

我的猜测是,通过使用Auth模块设置用户会话,它将用户令牌存储在正确的位置,以便Auth.currentAuthenticatedUser可以选择它。

  cognitoUser = new CognitoUser(userData);
  cognitoUser.setSignInUserSession(userSession);
  let authUser = Auth.createCognitoUser(cognitoUser.getUsername())
  authUser.setSignInUserSession(userSession)

创建cognitoUser可能不是必需的,但是它可以正常工作,所以我很满意。