0

当我从单元测试调用它时,这种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, IDictionaryemplacement 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;
        }
4

0 回答 0