在使用msal-react时,可以通过以下步骤从初始回调中检索令牌:
下面是一个示例代码,展示了如何在初始回调时从msal-react中检索令牌:
import { MsalProvider, MsalAuthenticationTemplate, useMsal } from "@azure/msal-react";
import { InteractionStatus } from "@azure/msal-browser";
const msalConfig = {
auth: {
clientId: "yourClientId",
authority: "https://login.microsoftonline.com/yourTenantId",
redirectUri: "http://localhost:3000"
}
};
const App = () => {
return (
<MsalProvider instance={msalInstance}>
<MsalAuthenticationTemplate interactionStatus={InteractionStatus.Startup}>
<MyAuthenticatedComponent />
</MsalAuthenticationTemplate>
</MsalProvider>
);
};
const MyAuthenticatedComponent = () => {
const { accounts, inProgress } = useMsal();
if (inProgress === InteractionStatus.Startup) {
return <div>Loading...</div>;
}
if (accounts.length === 0) {
return <div>No accounts detected.</div>;
}
const accessToken = accounts[0].accessToken;
const expiresOn = accounts[0].expiresOn;
return (
<div>
<p>Access Token: {accessToken}</p>
<p>Expires On: {expiresOn}</p>
</div>
);
};
export default App;
在上面的示例中,我们使用了MsalProvider组件来配置MSAL,并使用MsalAuthenticationTemplate组件来包裹需要进行身份验证的部分。在MyAuthenticatedComponent组件中,我们使用了useMsal()钩子函数来获取令牌和到期时间。
请注意,上述示例中的配置选项和代码仅供参考,实际使用时需要根据你的具体情况进行调整。
腾讯云相关产品和产品介绍链接地址:
请注意,以上链接仅供参考,具体的产品选择和推荐应根据实际需求和情况进行。
领取专属 10元无门槛券
手把手带您无忧上云