【问题标题】:aws-amplify auth currentSession returns no current useraws-amplify auth currentSession 不返回当前用户
【发布时间】:2019-05-06 21:44:15
【问题描述】:

使用:Nodejs + aws-amplify

来自aws amplify documentation,但是登录后我没有成功检查用户。

index.js

const Amplify = require('aws-amplify');
global.fetch = require('node-fetch'); // [source](https://github.com/aws-amplify/amplify-js/issues/876)
global.navigator = {};

Amplify.default.Auth({
    identityPoolId: IDENTITYPOOLID,
    region: REGION,
    userPoolId: USERPOOLID,
    userPoolWebClientId: APPCLIENTID,
});

Amplify.Auth.signIn(username, password).then(user => {
    localstorage.set('user', JSON.stringify(user));
    console.log(user); // "cognitoUser" object
    return Amplify.Auth.getSession();
}).then(session => {
    console.log(session); // "CognitoSession" object
}).catch(err => {
    console.log(err);
});

// PROBLEM
Amplify.Auth.getSession().then(session => {
    console.log(session);
}).catch(err => {
    console.log(err); // PRINT: no current user
});

看起来我无法获取用户会话,除非它包含在 Auth.signIn 中。我试过用;

// Problem
let userObj = JSON.parse(localstorage.get('use'));
Amplify.Auth.userSession(userObj).then(data => {
    console.log(data);
});
/// getSession is not a function

console.log(Amplfy.Auth.userSession); // PRINT: [Function]

我可以验证 userSession 是函数并且在库中,我看到的问题是getSession() 不在我存储在本地存储中的 CognitoUser 对象中。

如果这是问题所在,我找不到任何可以帮助我将 localstorage 对象转换为 CognitoObj 的函数。我唯一能做的就是每次都签署用户,这忽略了这个库的全部目的。

我错过了什么吗?为什么Amplify.Auth 不起作用?有没有办法检查任一用户的会话是否过期并手动刷新它?

我有与github 类似的问题。

【问题讨论】:

    标签: node.js asynchronous promise async-await aws-amplify


    【解决方案1】:

    看起来我无法获取用户会话,除非它包含在 Auth.signIn 中

    简而言之,这就是 Node/JS 异步编程模型。如果您在异步操作之间有一些时间依赖性,则必须将后面的操作包装在回调或 then 中,和/或相反地将早期的操作包装在 awaited 承诺中。

    事实上,如果你有一些可以并发运行的异步操作/相互之间没有依赖关系,你可以用Promise.all API优化你的代码,让它同时发送所有异步请求,并在最后一个完成。

    Top-level await 可能会帮助解决这样的用例。

    【讨论】:

      【解决方案2】:

      我也遇到了同样的问题,最后写成这样。

      import Auth from "@aws-amplify/auth";
      Auth.currentAuthenticatedUser().then((user) => {
        const session = user.getSignInUserSession();
        if (session) {
          AWS.config.credentials = new AWS.CognitoIdentityCredentials({
            IdentityPoolId: "REGION:POOL_ID",
            Logins: {
              "cognito-idp.REGION.amazonaws.com/ID": session
                .getIdToken()
                .getJwtToken(),
            },
          });
        }
      });
      

      【讨论】:

        猜你喜欢
        • 2018-08-28
        • 1970-01-01
        • 2020-02-04
        • 2020-08-30
        • 2021-05-04
        • 2019-09-02
        • 2023-03-22
        • 2020-09-20
        • 2020-11-18
        相关资源
        最近更新 更多