WCF и брандмауэр - PullRequest
       11

WCF и брандмауэр

0 голосов
/ 04 марта 2009

Я написал очень простой сервис WCF (размещенный в IIS) и веб-приложение, которое общается с ним. Если они оба находятся в одном домене, все работает нормально. Но когда я помещаю их в разные домены (по разные стороны брандмауэра), веб-приложения говорят:

Запрос токена безопасности не может быть выполнен из-за сбоя аутентификации. Описание: во время выполнения текущего веб-запроса произошло необработанное исключение. Пожалуйста, просмотрите трассировку стека для получения дополнительной информации об ошибке и о том, где она возникла в коде. Сведения об исключении: System.ServiceModel.FaultException: запрос маркера безопасности не может быть выполнен из-за сбоя аутентификации. Ошибка источника: Во время выполнения текущего веб-запроса было сгенерировано необработанное исключение. Информацию о происхождении и местонахождении исключения можно определить с помощью приведенной ниже трассировки стека исключений.

Основная часть сервиса web.config:

<system.serviceModel>
<services>
  <service behaviorConfiguration="MigrationHelperBehavior"
    name="MigrationHelper">
    <endpoint address="" binding="wsHttpBinding" contract="IMigrationHelper">
      <identity>
        <dns value="localhost" />
      </identity>
    </endpoint>
    <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange" />        <endpoint  binding="httpBinding" contract="IMigrationHelper" />       </service>
</services>
<behaviors>
  <serviceBehaviors>
    <behavior name="MigrationHelperBehavior">
      <!-- To avoid disclosing metadata information, set the value below to false and remove the metadata endpoint above before deployment -->
      <serviceMetadata httpGetEnabled="true"/>
      <!-- To receive exception details in faults for debugging purposes, set the value below to true. Set to false before deployment to avoid disclosing exception information -->
      <serviceDebug includeExceptionDetailInFaults="false"/>
    </behavior>
  </serviceBehaviors>
</behaviors>
</system.serviceModel> 

Веб-приложение (клиент) web.config говорит:

<system.serviceModel>
<bindings>
<wsHttpBinding>
<binding name="WSHttpBinding_IMigrationHelper" closeTimeout="00:01:00" openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00" bypassProxyOnLocal="false" transactionFlow="false" hostNameComparisonMode="StrongWildcard" maxBufferPoolSize="524288" maxReceivedMessageSize="65536" messageEncoding="Text" textEncoding="utf-8" useDefaultWebProxy="true" allowCookies="false">
    <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384" maxBytesPerRead="4096" maxNameTableCharCount="16384"/>
    <reliableSession ordered="true" inactivityTimeout="00:10:00" enabled="false"/>
    <security mode="Message">
        <transport clientCredentialType="Windows" proxyCredentialType="None" realm=""/>
        <message clientCredentialType="Windows" negotiateServiceCredential="true" algorithmSuite="Default" establishSecurityContext="true"/>
    </security>
</binding>
</wsHttpBinding>
</bindings>
<client>
<endpoint address="http://mydomain.com/MigrationHelper.svc" binding="wsHttpBinding" bindingConfiguration="WSHttpBinding_IMigrationHelper" contract="MyNewServiceReference.IMigrationHelper" name="WSHttpBinding_IMigrationHelper">
<identity>
    <dns value="localhost"/>
</identity>
</endpoint>
</client>
</system.serviceModel>

Я полагаю, что оба эти варианта являются стандартными, которые VS 2008 создал для меня.

Итак, мой вопрос: как можно настроить службу и клиента, если они не находятся в одном домене?

Спасибо .Джим Биддисон

Ответы [ 2 ]

1 голос
/ 18 апреля 2011

Кажется, вы хотите / используете проверку подлинности Windows, которая в междоменной ситуации, как правило, отличается. Кажется, это не проблема брандмауэра.

Чтобы решить проблему аутентификации Windows по умолчанию, используйте сертификат или ничего не используйте.

0 голосов
/ 04 марта 2009

См. Ответ на мой вопрос о том, как настроить трассировку WCF. Как настроена безопасность для веб-приложения службы?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...