У меня проблема с получением токена из моего httpContext
в проекте Asp.Net Core 2.0.У меня есть неявная авторизация ADAL в передней части, где я получаю токен и отправляю его в заголовке при доступе к моему API.Аутентификация идет хорошо, но когда я хочу получить токен для запроса к Microsoft Graph API, я получаю null
.
Моя Startup
часть аутентификации:
services.AddAuthentication(options =>
{
options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
}).AddJwtBearer(options =>
{
AuthenticationOptions authSettings = Configuration.GetSection("Authentication").Get<AuthenticationOptions>();
options.TokenValidationParameters = new TokenValidationParameters()
{
ValidateIssuer = false,
ValidAudiences = new List<string> { authSettings.ClientId, authSettings.AppIdUri }
};
options.Authority = "https://login.microsoftonline.com/common";
options.Audience = "**";
options.TokenValidationParameters.ValidateLifetime = true;
options.TokenValidationParameters.ClockSkew = TimeSpan.Zero;
options.SaveToken = true;
});
services.AddAuthorization();
services.AddMvc();
Метод, в котором мне нужно получить токен:
public async Task AuthenticateRequestAsync(HttpRequestMessage request)
{
var httpContext = _httpContextAccessor.HttpContext;
//Get the access token used to call this API
string token = await httpContext.GetTokenAsync("access_token");
//We are passing an *assertion* to Azure AD about the current user
//Here we specify that assertion's type, that is a JWT Bearer token
string assertionType = "urn:ietf:params:oauth:grant-type:jwt-bearer";
//User name is needed here only for ADAL, it is not passed to AAD
//ADAL uses it to find a token in the cache if available
var user = httpContext.User;
string userName = user.FindFirstValue(ClaimTypes.Upn) ?? user.FindFirstValue(ClaimTypes.Email);
var userAssertion = new UserAssertion(token, assertionType, userName);
//Construct the token cache
var cache = new DistributedTokenCache(user, _distributedCache, _loggerFactory, _dataProtectionProvider);
var authContext = new AuthenticationContext(_authSettings.Authority, cache);
var clientCredential = new ClientCredential(_authSettings.ClientId, _authSettings.ClientSecret);
//Acquire access token
var result = await authContext.AcquireTokenAsync("https://graph.microsoft.com", clientCredential, userAssertion);
//Set the authentication header
request.Headers.Authorization = new AuthenticationHeaderValue(result.AccessTokenType, result.AccessToken);
}
В части await httpContext.GetTokenAsync("access_token");
возвращается null
.