【发布时间】:2021-05-25 04:39:58
【问题描述】:
我正在尝试使用 MSAL.JS 编写一个函数来获取 Bearer 令牌并在代表用户调用 API 之前返回标头。
我想我正在为等待/异步/承诺而苦苦挣扎。我不太熟悉的东西,至少在 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”是未定义的,看起来像是在令牌检索之前执行的。
【问题讨论】:
标签: javascript async-await promise msal.js