Ошибка согласования безопасности SOAP в дуплексной службе WCF - PullRequest
0 голосов
/ 14 июля 2011

Я работаю над службой WCF с дуплексной связью, и у меня возникла проблема с тем, чтобы она работала где-либо еще, кроме как через localhost, на моем компьютере разработчика.

Независимо от того, что я делаю, он предлагает следующееошибка:

{"Ошибка аутентификации интерфейса поставщика поддержки безопасности (SSPI). Возможно, сервер не работает под учетной записью с идентификатором" host / crpnyciis20e ". Если сервер работает под учетной записью службы (Сетевая служба, например), укажите ServicePrincipalName учетной записи в качестве идентификатора в EndpointAddress для сервера. Если сервер работает под учетной записью пользователя, укажите UserPrincipalName учетной записи в качестве идентификатора в EndpointAddress для сервера. "}

Мой сервис Web.config выглядит следующим образом:

<?xml version="1.0"?>
<configuration>    
  <system.web>
    <compilation debug="true" targetFramework="4.0" />
  </system.web>
  <system.serviceModel>
    <protocolMapping>
      <add scheme="http" binding="wsDualHttpBinding"/>
    </protocolMapping>
    <behaviors>
      <serviceBehaviors>
        <behavior>
          <serviceMetadata httpGetEnabled="true"/>
          <serviceDebug includeExceptionDetailInFaults="true"/>
        </behavior>
      </serviceBehaviors>
    </behaviors>
    <serviceHostingEnvironment multipleSiteBindingsEnabled="true" />
  </system.serviceModel>
  <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
  </system.webServer>
</configuration>

И мой клиент App.config:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <system.serviceModel>
        <bindings>
            <wsDualHttpBinding>
                <binding name="WSDualHttpBinding_IMessagingService" 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">
                    <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
                        maxBytesPerRead="4096" maxNameTableCharCount="16384" />
                    <reliableSession ordered="true" inactivityTimeout="00:10:00" />
                    <security mode="Message">
                        <message clientCredentialType="Windows" negotiateServiceCredential="true"
                            algorithmSuite="Default" />
                    </security>
                </binding>
            </wsDualHttpBinding>
        </bindings>
        <client>
            <endpoint
                binding="wsDualHttpBinding" bindingConfiguration="WSDualHttpBinding_IMessagingService"
                contract="CTMessagingServiceReference.IMessagingService" name="WSDualHttpBinding_IMessagingService">
                <identity>
                    <userPrincipalName value="nbdfp2k" />
                </identity>
            </endpoint>
        </client>
    </system.serviceModel>
</configuration>

Любые идеи, которые я мог бы сделать, чтобы обойти эту проблему?Если есть какой-либо другой код, который будет полезен при диагностике, просто дайте мне знать ... ничего из этого на самом деле не имеет отношения к конфигурации соединения, о которой я знаю.

Ответы [ 2 ]

1 голос
/ 10 мая 2012

Не уверен, решит ли это вашу проблему, но вам не хватает адреса в конечной точке клиента, а также адреса базы клиента в конфигурации привязки (он должен отличаться от адреса конечной точки).

0 голосов
/ 04 января 2014

Не уверен, что это идеальный способ сделать это, но вы можете попробовать удалить следующий «идентификатор» узла из конфигурации клиента -

<identity>
     <userPrincipalName value="nbdfp2k" />
</identity>
...