我正在尝试从Xamarin表单应用程序获取来自azure AD的令牌。我使用的是ADAL 4+,我不希望用户每次启动应用程序时都要登录。在用户成功登录后重新启动应用程序时,是否需要以编程方式刷新或获取令牌。
由于ADAL不再有userPasswordCredientian()。我找不到任何替代方案来解决这个问题。
发布于 2019-04-11 01:26:11
一旦ADAL.NET获得了用户的令牌,它就会将其与刷新令牌一起缓存。然后,下次应用程序需要令牌时,它应该首先调用AcquireTokenSilentAsync来验证缓存中是否有可接受的令牌。如果存在令牌但已过期,则AcquireTokenSilentAsync将使用缓存的刷新令牌来刷新访问令牌,如果缓存中没有令牌,则可能需要进行交互式呼叫以让用户再次登录。
Here's some more information on how this works in ADAL
这是推荐的呼叫模式,首先执行AT静默呼叫,并捕获AdalSilentTokenAcquisitionException (因为找不到令牌),然后执行AT交互式呼叫。
AuthenticationContext ac = new AuthenticationContext(authority);
AuthenticationResult result=null;
try
{
result = await ac.AcquireTokenSilentAsync(resource, clientId);
}
catch (AdalException adalException)
{
if (adalException.ErrorCode == AdalError.FailedToAcquireTokenSilently
|| adalException.ErrorCode == AdalError.InteractionRequired)
{
result = await ac.AcquireTokenAsync(resource, clientId, redirectUri,
new PlatformParameters(PromptBehavior.Auto));
}
}我建议迁移到MSAL...这里是MSAL语言中的documentation on the differences between ADAL and MSAL和specifics on the username/password flow,以及如何从ADAL.NET 4.x to MSAL.NET 2.x和刚刚发布的MSAL v3 api迁移。
https://stackoverflow.com/questions/55612179
复制相似问题