Назад | Перейти на главную страницу

Получение согласования аутентификации вместо NTLM при использовании службы SOAP WCF в Net.Core 2.1

Я пытался подключиться к службе WCF SOAP с использованием схемы проверки подлинности NTLM, мне это удалось при использовании .Net Framework 4.x, но когда я пытаюсь использовать ту же службу в .NET Core 2.1, это не удается (поскольку отправляется схема проверки подлинности as Negotiate, несмотря на то, что я установил Ntlm в коде), я использовал скрипач и прилагаю несколько его изображений.

Заголовок Net Framework 4.x

Заголовки Net Core 2.1

И это исходный код, который я использую .NetCore2.1 и .NetFramework 4.5.x (в котором отлично работает):

System.ServiceModel.Channels.CustomBinding binding = new System.ServiceModel.Channels.CustomBinding();
System.ServiceModel.Channels.TextMessageEncodingBindingElement textBindingElement = new System.ServiceModel.Channels.TextMessageEncodingBindingElement();
binding.Elements.Add(textBindingElement);
System.ServiceModel.Channels.HttpsTransportBindingElement httpsBindingElement = new System.ServiceModel.Channels.HttpsTransportBindingElement();
httpsBindingElement.AllowCookies = true;
httpsBindingElement.MaxBufferSize = int.MaxValue;
httpsBindingElement.MaxReceivedMessageSize = int.MaxValue;
httpsBindingElement.AuthenticationScheme = System.Net.AuthenticationSchemes.Ntlm;
binding.Elements.Add(httpsBindingElement);
return binding;

_client.ClientCredentials.Windows.ClientCredential.Domain = "domain";
_client.ClientCredentials.Windows.ClientCredential.UserName = "username";
_client.ClientCredentials.Windows.ClientCredential.Password = "password";
_client.ClientCredentials.Windows.AllowedImpersonationLevel = System.Security.Principal.TokenImpersonationLevel.Impersonation;

Ошибка, которую я получаю в .NetCore2.1:

Произошла одна или несколько ошибок. (HTTP-запрос неавторизован со схемой аутентификации клиента «Ntlm». Заголовок аутентификации, полученный от сервера, был «NTLM, Negotiate».)

Любая помощь будет очень признательна, спасибо !.