C#-Oauth令牌访问
作者:互联网
我想获取访问令牌以使用它来使用Microsoft图形API从Outlook中获取电子邮件.我的应用程序将是基于控制台的c#应用程序,它将在每20分钟自动运行一次并提取电子邮件.
我是C#和Microsoft图形的新手,这是我与这些技术相关的第一项任务.
问题是:
当我尝试使用client_Credentials来获取令牌时,我成功地做到了,但是现在令牌已过期,我想获取新令牌,如果我尝试生成新令牌,则仅返回过期的令牌.
相关代码:
result = await context.AcquireTokenAsync(resourceUri, clientCredential);
使用AcquireTokenSilentAsync方法返回错误:
“由于无法在缓存中找到令牌,因此无法以静默方式获取令牌.调用方法AcquireToken.”
相关代码:
result = await authContext.AcquireTokenSilentAsync(resourceUri, clientId);
我的问题:
>使用客户端凭据访问令牌是否是满足我的需求的正确方法?
>我已经读到,使用client_Credentials并不需要refresh_token,每次尝试连接时,我们都会获得新令牌.
>每次我想连接时如何获取新令牌?
>如果没有提出任何关于如何实现我的主要目标的建议,我们将深表欢迎.
我附上我的代码示例:
static async Task getAccessToken()
{
authContext = new AuthenticationContext("https://login.microsoftonline.com/<tenantId>");
try
{
result = await authContext.AcquireTokenSilentAsync(resourceUri, clientId);
}
catch (Exception ex)
{
Console.WriteLine(ex);
try
{
result = await authContext.AcquireTokenAsync(resourceUri, clientCredential);
Console.WriteLine("" + result.AccessToken+"\n\n");
}
catch (Exception e)
{
Console.WriteLine("\n AcquireTokenAsync failed\n");
Console.WriteLine(""+e);
}
}
if (result == null)
{
Console.WriteLine("Canceling attempt to get access token.\n");
return;
}
Console.WriteLine(result.AccessToken);
}
解决方法:
您正在混合两个不同的OAuth流(授权代码和客户端凭据).您只需要使用正确的凭据调用AcquireTokenAsync.每当您需要一个新令牌(每个令牌的寿命大约为一个小时)时,您都将重新执行此方法以获取一个新令牌:
static async Task<AuthenticationResult> getAccessToken()
{
ClientCredential clientCredential = new ClientCredential("YOUR_APP_ID", "YOUR_APP_SECRET");
AuthenticationContext authContext = new AuthenticationContext("https://login.microsoftonline.com/YOUR_TENANT_ID");
AuthenticationResult result = null;
try
{
result = await authContext.AcquireTokenAsync("https://graph.microsoft.com", clientCredential);
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
if (result == null)
Console.WriteLine("Canceling attempt to get access token.");
else
Console.WriteLine(result.AccessToken);
return result;
}
标签:microsoft-graph,adal,c 来源: https://codeday.me/bug/20191211/2105989.html