Подключение к веб-сервису asmx через WCF через прокси
Извините, ответ найден при наборе
Я пытаюсь подключиться к внешнему веб-сервису, который требует аутентификации по имени пользователя и паролю через прокси. Я использую Visual Studio Express 2008 для создания ссылки на службу
Я подключился к той же веб-службе с помощью веб-ссылки. Нам нужно было только установить большее время ожидания, потому что это занимает много времени, чтобы закончить.Я подключился к другому веб-сервису, который не требует аутентификации по имени пользователя / паролю с созданной ссылкой на службу и некоторыми настройками, чтобы получить ее через прокси.Поэтому я хотел бы взять эту ссылку, указать ее на правильный веб-сервис и добавить аутентификацию.
Конфиг, который я использую без безопасности:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.net>
<defaultProxy useDefaultCredentials="true">
<proxy bypassonlocal="False" proxyaddress="http://***.***.****:80" />
</defaultProxy>
</system.net>
<system.serviceModel>
<bindings>
<customBinding>
<binding name="AreaWebServiceSoap12">
<textMessageEncoding maxReadPoolSize="64" maxWritePoolSize="16"
messageVersion="Soap12" writeEncoding="utf-8">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
</textMessageEncoding>
<httpTransport manualAddressing="false" maxBufferPoolSize="524288"
maxReceivedMessageSize="65536" allowCookies="false" authenticationScheme="Anonymous"
bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard"
keepAliveEnabled="true" maxBufferSize="65536" proxyAuthenticationScheme="Anonymous"
realm="" transferMode="Buffered" unsafeConnectionNtlmAuthentication="false"
useDefaultWebProxy="true" />
</binding>
</customBinding>
</bindings>
<client>
<endpoint address="http://www.****.*****.****.com/samplewebservice/service.asmx"
binding="customBinding" bindingConfiguration="AreaWebServiceSoap12"
contract="ServiceReference1.ServiceSoap" name="ServiceSoap" />
</client>
</system.serviceModel>
</configuration>
Я добавил следующий код для проверки подлинности:
static void Main(string[] args)
{
ServiceSoapClient s = new ServiceSoapClient();
s.ClientCredentials.UserName.UserName = @"username";
s.ClientCredentials.UserName.Password = @"password";
Service.RawGpsData[] result = s.GetRawGpsData(0);
Console.WriteLine(String.Format("done:{0}",result.Length));
Console.ReadLine();
}
Просто использование этой настройки дает ошибку, как и ожидалось:
HTTP-запрос не авторизован со схемой аутентификации клиента Anonymous. Заголовок аутентификации с сервера получен, это NTLM.
Теперь я теряюсь и начинаю пробовать глупости, потому что я только начинаю использовать WCF.
Когда я добавляю следующий раздел в конфиг
<security authenticationMode="UserNameOverTransport"></security>
Я получаю следующую ошибку:
Привязка CustomBinding.http: / / tempuri.org / для контракта AreaWebServiceSoap.AreaWebServices настроена на режим проверки, для которого требуется транспортный уровень с целостностью и конфиденциальностью. Транспорт не может обеспечить целостность и конфиденциальность.
Извините, набирая этот вопрос, я сам наткнулся на ответ. Я все еще думаю, что люди могут быть заинтересованы в этом, и все комментарии и мысли все еще приветствуются. Поэтому я оставлю вопрос здесь, сделаю его сообществом и отправлю ответ сам.