如何解决MSAL.JS 的异步/等待/承诺问题
我正在尝试编写一个函数来获取不记名令牌并在代表用户调用 API 之前使用 MSAL.JS 返回标头。
我想我正在为等待/异步/承诺而苦苦挣扎。我不太熟悉的东西,至少在 JS 中是这样。
这是函数(我省略了 ssoSilent/login 的部分):
const prepareAPI = async (type) => {
const ssoRequest = {
loginHint: _userUpn,scopes: ["openid","profile","user.read",_APIscope]
};
// if the user is already logged in you can acquire a token
if (msalInstance.getAccount()) {
var tokenRequest = {
scopes: [_APIscope]
};
try {
const resp = await msalInstance.acquireTokenSilent(tokenRequest);
console.log(resp.accessToken);
var headers = new Headers();
var bearer = "Bearer " + resp.accessToken;
headers.append("Authorization",bearer);
resolve({
method: type,headers: headers
});
} catch (err) {
// could also check if err instance of InteractionRequiredAuthError if you can import the class.
if (err.name === "InteractionRequiredAuthError") {
return msalInstance.acquireTokenPopup(tokenRequest)
.then(response => {
return getOpts(response.accessToken,type);
})
.catch(err => {
console.log("Something went wrong:" + err);
});
}
}
} else {
// ... RequestSSO,loginPopup,etc,}
};
我这样调用函数:
prepareAPI("GET")
.then(opts => console.log("Headers: ",opts));
我在解析之前在 console.log(resp.accessToken) 中获得了令牌。 但是“opts”是未定义的,看起来是在token检索之前执行的。
解决方法
我在您的代码中没有看到任何理由使用异步等待以外的任何内容。通过将 .then 替换为 await 并删除任何 .catch 调用来简化代码(它会改为抛出)。确保任何异步调用(解决?)都有一个 await 语句。请记住,await 只是用于解析 Promise 的语法糖,它在解析时返回值或在拒绝时抛出。
前
prepareAPI("GET")
.then(opts => console.log("Headers: ",opts))
.catch(e => console.error(e));
变成
try {
const opts = await prepareAPI("GET");
console.log("Headers: ",opts)
} catch (e) {console.error(e);}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。