当我从单元测试调用它时,这种RequestClientCredentialsTokenAsync
生成令牌(oauth2)的方法对我来说很好,但是从 API MVC .Net Framework 4.6.1 我有这个异常:(对不起,异常是法语)
<Error>
<Message>
Une erreur s'est produite lors de l'envoi de la demande.
</Message>
<ExceptionMessage>
Une erreur s'est produite lors de l'envoi de la demande.
</ExceptionMessage>
<ExceptionType>System.InvalidOperationException</ExceptionType>
<StackTrace>
à JwtBearerAuthentication.JwtAssertionTokenManager.AcquireAccessToken() dans C:\Users\S851029\source\repos\Sources\AF.EFormSignature.JwtBearerAuthentication\JwtAssertionTokenManager.cs:ligne 55 à JwtBearerAuthentication.JwtAssertionTokenManager.GetAccessToken(Boolean forceRefresh) dans C:\Users\S851029\source\repos\Sources\AF.EFormSignature.JwtBearerAuthentication\JwtAssertionTokenManager.cs:ligne 28 à AF.EFormSignature.Web.Controllers.IdentiteNumeriqueController.RecuperationStatutIdentite() dans C:\Users\S851029\source\repos\Sources\AF.EFormSignature.Web\Controllers\IdentiteNumeriqueController.cs:ligne 72 à lambda_method(Closure , Object , Object[] ) à System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ActionExecutor.<>c__DisplayClass10.<GetExecutor>b__9(Object instance, Object[] methodParameters) à System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ActionExecutor.Execute(Object instance, Object[] arguments) à System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ExecuteAsync(HttpControllerContext controllerContext, IDictionary
emplacement précédent au niveau duquel l'exception a été levée --- à System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务)à System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务)à System.Web.Http.Filters .AuthorizationFilterAttribute.d__2.MoveNext() --- Fin de la trace de la pile à partir de l'emplacement précédent au niveau duquel l'exception a été levée --- à System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务) à System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) à System.Web.Http.Controllers.ExceptionFilterResult.d__0.MoveNext() 出现错误。Une erreur s'est produite lors de l'envoi de la demande。System.Net.Http.HttpRequestException → System.Runtime。CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务)à System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务)à IdentityModel.Client.HttpClientTokenRequestExtensions.d__7.MoveNext() 发生错误。无法从服务器远程 System.Net.WebException à System.Net.HttpWebRequest.EndGetRequestStream(IAsyncResult asyncResult, TransportContext& context) à System.Net.Http.HttpClientHandler.GetRequestStreamCallback(IAsyncResult ar) 发生错误。Une tentative de connexion a échoué car le parti connecté n'a pas répondu convenablement au-delà d'une certaine durée ou une connexion établie a échoué car l'hôte de connexion n'a pas répondu 171.18.28.75:443 System.Net。 Sockets.SocketException à System.Net。
private string AcquireAccessToken()
{
// Build assertion
var authenticationToken = GetAuthenticationToken();
HttpClientHandler handler = new HttpClientHandler();
handler.DefaultProxyCredentials = CredentialCache.DefaultCredentials;
HttpMessageInvoker msg = new HttpMessageInvoker(handler);
TokenClientOptions tokenClientOptions = new TokenClientOptions();
tokenClientOptions.Address = TokenEndpointUrl;
tokenClientOptions.ClientId = ClientId;
tokenClientOptions.ClientSecret = ClientSecret;
TokenClient tokenClient = new TokenClient(msg, tokenClientOptions);
var payload = new Dictionary<string, string> {
{ "client_assertion_type", "urn:ietf:params:oauth:client-assertion-type:jwt-bearer" },
{ "client_assertion", authenticationToken }
};
// Send authorization parameters using HTTP POST method and the Form Serialization
// See http://openid.net/specs/openid-connect-core-1_0.html#ClientAuthentication
var tokenResponse = tokenClient.RequestClientCredentialsTokenAsync(Scope, payload);
if (tokenResponse.Result.IsError)
{
throw new InvalidOperationException(tokenResponse.Result.Exception.Message, tokenResponse.Result.Exception);
}
var accessToken = tokenResponse.Result.AccessToken;
// Get token expiration date to configure cache expiration
var accessTokenExpiration = GetTokenExpirationDate(accessToken);
// Cache access token to prevent calling MAAM server for each request
WriteTokenToCache(GenerateTokenCacheKey(), accessToken, new DateTimeOffset(accessTokenExpiration));
return accessToken;
}