2016-11-05 7 views
1

я получаю маркер доступа от IdSrv4 и когда я пытаюсь вызвать мой апи с этим маркеромIdentityServer3.AccessTokenValidation API и IdentityServer4

var client = new HttpClient(); 
client.SetBearerToken(token.AccessToken); 
var response = await client.GetAsync("http://localhost:60602/api/users"); 

я получаю сообщение об ошибке:

Microsoft.Owin.Security.OAuth.OAuthBearerAuthenticationMiddleware Error: 0 : Authentication failed System.InvalidOperationException: Sequence contains no elements at System.Linq.Enumerable.First[TSource](IEnumerable 1 source) at IdentityServer3.AccessTokenValidation.DiscoveryDocumentIssuerSecurityTokenProvider.<RetrieveMetadata>b__1(JsonWebKey key) in c:\local\identity\server3\AccessTokenValidation\source\AccessTokenValidation\Plumbing\DiscoveryDocumentIssuerSecurityTokenProvider.cs:line 152 at System.Linq.Enumerable.WhereSelectListIterator 2.MoveNext() at System.IdentityModel.Tokens.JwtSecurityTokenHandler.ResolveIssuerSigningKey(String token, SecurityToken securityToken, SecurityKeyIdentifier keyIdentifier, TokenValidationParameters validationParameters) at System.IdentityModel.Tokens.JwtSecurityTokenHandler.ValidateSignature(String token, TokenValidationParameters validationParameters) at System.IdentityModel.Tokens.JwtSecurityTokenHandler.ValidateToken(String securityToken, TokenValidationParameters validationParameters, SecurityToken& validatedToken) at Microsoft.Owin.Security.Jwt.JwtFormat.Unprotect(String protectedText) at Microsoft.Owin.Security.OAuth.OAuthBearerAuthenticationHandler.d__0.MoveNext()

Я прочитал эту проблему и добавить сертификат, сгенерированный этим кодом https://github.com/ElemarJR/LearningIdentityServer4/tree/master/LearningIdentityServer.OAuth

но без успеха.

WebAPI код ...

app.UseCookieAuthentication(new CookieAuthenticationOptions()); 
app.UseExternalSignInCookie(DefaultAuthenticationTypes.ExternalCookie); 
JwtSecurityTokenHandler.InboundClaimTypeMap.Clear(); 
app.UseIdentityServerBearerTokenAuthentication(new IdentityServerBearerTokenAuthenticationOptions 
{ 
     Authority = "http://localhost:5000",//Constants.BaseAddress, 
     RequiredScopes = new[] { "api1" }, 
}); 

...

какие-либо предложения?

+0

Взгляните https://github.com/IdentityServer/IdentityServer3.AccessTokenValidation/issues/108 Кажется, что есть решение. –

ответ