MSMQ + WCF: режим WindowsDomain MsmqAuthenticationMode требует SID отправителя

Я получаю следующую ошибку при попытке отправить / получить очередь MSMQ с использованием WCF:

"Не удалось создать контекст безопасности сообщения, поскольку в сообщении не найден идентификатор SID отправителя. Сообщение не может быть получено. Для режима WindowsDomain MsmqAuthenticationMode требуется идентификатор SID отправителя".

Это приводит к сбою всех сообщений и, следовательно, перемещению в другую очередь ядов. Похоже, что ошибка происходит при получении услуги.

Конфигурация клиента выглядит следующим образом:

<netMsmqBinding>
    <binding name="OrderServiceMsmqBinding"
              durable="true"
              exactlyOnce="true"
              maxReceivedMessageSize="2147483647"
              maxRetryCycles="1"
              receiveErrorHandling="Move"
              receiveRetryCount="1"
              retryCycleDelay="00:0:05"
              deadLetterQueue="Custom"
              customDeadLetterQueue="net.msmq://localhost/private/Services.DeadOrderListenerService/DeadOrderListenerService.svc"                  
              useMsmqTracing="true">
      <security mode="None" />
      <readerQuotas maxStringContentLength="2147483647" />
    </binding>
  </netMsmqBinding>

так же как:

<client>
      <endpoint address="net.msmq://localhost/private/Services.OrderPlacementProviderService/OrderPlacementProviderService.svc" binding="netMsmqBinding" bindingConfiguration="OrderServiceMsmqBinding" contract="Providers.IOrderPlacementService" name="orderingMsmqEndpoint" />
</client>

Служба получения настроена почти так же:

<netMsmqBinding>       
        <binding name="OrderServiceMsmqBinding"
                 durable="true"
                 exactlyOnce="true"                 
                 maxReceivedMessageSize="2147483647"                      
                 maxRetryCycles="1"
                 receiveErrorHandling="Move"
                 receiveRetryCount="1"
                 retryCycleDelay="00:0:05"
                 deadLetterQueue="Custom"                 customDeadLetterQueue="net.msmq://localhost/private/Services.DeadOrderListenerService/DeadOrderListenerService.svc"
                 timeToLive="00:01:00"
                 useActiveDirectory="false"
                 useMsmqTracing="true">
          <readerQuotas maxStringContentLength="2147483647" />
        </binding>
      </netMsmqBinding>

А также:

<service name="Services.OrderPlacementProviderService" behaviorConfiguration="OrderServiceBehavior">
        <endpoint address="mex" binding="mexHttpBinding" bindingConfiguration="" name="MexOrderService" contract="IMetadataExchange" />
        <endpoint address="net.msmq://localhost/private/Services.OrderPlacementProviderService/OrderPlacementProviderService.svc" binding="netMsmqBinding" bindingConfiguration="OrderServiceMsmqBinding" contract="Providers.IOrderPlacementService" name="msmqEndpoint" />
        <host>
          <baseAddresses>
            <add baseAddress="http://localhost/Services.OrderPlacementProviderService" />
          </baseAddresses>
        </host>
      </service>

Очереди не проходят проверку подлинности и в настоящее время имеют доступ ко всем пользователям. Эта проблема SID только началась. Это постоянно происходит в разных средах, поэтому я предполагаю, что настроил что-то неправильно?

Еще немного информации: клиент размещает заказ (в очереди) следующим образом:

 using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required))
 {
      _orderPlacementClient.PlaceOrder(basket, transactionRef, user);       
      scope.Complete();
 }     

и сервис прослушивания выглядит так:

[OperationBehavior(TransactionScopeRequired = true, TransactionAutoComplete = true)]
    public void PlaceOrder(BasketDTO basket, string transactionReference, UserDTO user)
    {
        _log.Info("Order placed: " + transactionReference + " for user " + user.Id);
        try 
        {
            _prov.PlaceOrder(basket, transactionReference, user);                
        }
        catch (Exception ex)
        {
            _log.Error("Error placing order", ex);
        }           
    }

0 ответов

Другие вопросы по тегам