Как я могу отладить клиент WCF, используя имя пользователя / пароль в заголовке, зашифрованном с помощью SSL - PullRequest
1 голос
/ 09 декабря 2011

Я все еще пытаюсь заставить WCF поговорить с CXF. Я использовал пример из http://rocksolidknowledge.com/Download.mvc, и мне кажется, что код работает, потому что, когда я меняю имя пользователя в клиенте, я вижу новое имя пользователя в сервисе.

Я попытался добавить запись в клиентском app.config, чтобы сохранить то, что отправляется в службу.

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <system.serviceModel>
        <bindings>
            <wsHttpBinding>
              <binding name="WSHttpBinding_Av1Service" 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="TransportWithMessageCredential">
                        <transport clientCredentialType="None" proxyCredentialType="None"
                            realm="" />
                        <message clientCredentialType="UserName" negotiateServiceCredential="true"
                            algorithmSuite="Default" establishSecurityContext="true" />
                    </security>

                <!--
                <security mode="None">
                  <transport clientCredentialType="None" proxyCredentialType="None"
                      realm="" />
                  <message clientCredentialType="UserName" negotiateServiceCredential="true"
                      algorithmSuite="Default" establishSecurityContext="true" />
                </security>
                -->
              </binding>
            </wsHttpBinding>
        </bindings>
      <behaviors>
        <endpointBehaviors>

          <behavior name="client">
            <clientCredentials>
              <serviceCertificate>
                <authentication certificateValidationMode="None"/>
              </serviceCertificate>
            </clientCredentials>
          </behavior>
        </endpointBehaviors>
      </behaviors>
        <client>

            <endpoint address="https://darsdevlaptop:8015/DarsWebServices/services/av1" binding="wsHttpBinding"
                bindingConfiguration="WSHttpBinding_Av1Service" contract="Av1ServiceReference.Av1Service"
                name="WSHttpBinding_Av1Service" />

          <!--
            <endpoint 
              address="http://localhost:9015/DarsWebServices/services/av1" binding="wsHttpBinding"
                bindingConfiguration="WSHttpBinding_Av1Service" contract="Av1ServiceReference.Av1Service"
                name="WSHttpBinding_Av1Service" />
          -->
        </client>
      <diagnostics>
        <messageLogging logEntireMessage="true"
                        logMalformedMessages="true"
                        logMessagesAtServiceLevel="true"
                        logMessagesAtTransportLevel="true"
                        maxMessagesToLog="3000"
                        maxSizeOfMessageToLog="2000"/>
      </diagnostics>
    </system.serviceModel>
</configuration>

Эта конфигурация создает файл client_msg.svclog, который я могу просматривать с помощью Microsoft Service Trace Viewer. И внутри этого файла я вижу

E2ETraceEvent xmlns="http://schemas.microsoft.com/2004/06/E2ETraceEvent">
<System xmlns="http://schemas.microsoft.com/2004/06/windows/eventlog/system">
<EventID>0</EventID>
<Type>3</Type>
<SubType Name="Information">0</SubType>
<Level>8</Level>
<TimeCreated SystemTime="2011-12-08T15:27:46.1360000Z" />
<Source Name="System.ServiceModel.MessageLogging" />
<Correlation ActivityID="{00000000-0000-0000-0000-000000000000}" />
<Execution ProcessName="Clieint.vshost" ProcessID="5660" ThreadID="10" />
<Channel />
<Computer>DARSDEVLAPTOP</Computer>
</System>
<ApplicationData>
<TraceData>
<DataItem>
<MessageLogTraceRecord Time="2011-12-08T10:27:46.1320000-05:00" Source="ServiceLevelSendRequest" Type="System.ServiceModel.Channels.BodyWriterMessage" xmlns="http://schemas.microsoft.com/2004/06/ServiceModel/Management/MessageTrace">
<HttpRequest>
<Method>POST</Method>
<QueryString></QueryString>
<WebHeaders>
<VsDebuggerCausalityData>uIDPo7bjbPmwsKdKqJIT7OFhvN8AAAAA+hhv3g5Q+UymaaUAoh1MoXMwGPaCPSlAoTQw7kFj3m8ACQAA</VsDebuggerCausalityData>
</WebHeaders>
</HttpRequest>
<s:Envelope xmlns:a="http://www.w3.org/2005/08/addressing" xmlns:s="http://www.w3.org/2003/05/soap-envelope">
<s:Header>
<a:Action s:mustUnderstand="1">http://tempuri.org/IPing/Ping</a:Action>
<a:MessageID>urn:uuid:85d46f93-9798-41c4-a8fd-e862b3858d46</a:MessageID>
<a:ReplyTo>
<a:Address>http://www.w3.org/2005/08/addressing/anonymous</a:Address>
</a:ReplyTo>
</s:Header>
<s:Body>
<Ping xmlns="http://tempuri.org/"></Ping>
</s:Body>
</s:Envelope>
</MessageLogTraceRecord>
</DataItem>
</TraceData>
</ApplicationData>

И я с ужасом не нахожу никаких ссылок на имя пользователя или пароль

<s:Header>
    <a:Action s:mustUnderstand="1">http://tempuri.org/IPing/Ping</a:Action>
    <a:MessageID>urn:uuid:85d46f93-9798-41c4-a8fd-e862b3858d46</a:MessageID>
    <a:ReplyTo>
        <a:Address>http://www.w3.org/2005/08/addressing/anonymous</a:Address>
    </a:ReplyTo>
</s:Header>

Я также попытался запустить fiddler2, но я не вижу там ни имени пользователя / пароля. Так что же происходит? Я скучаю по тому, как использовать инструменты просмотра? Это передается не в шапке? Если так, как бы я это исправить!

Просто чтобы объяснить, почему я забочусь об этом:

  • Я передал код, основанный на образце, своему клиенту, чтобы поговорить с CXF сервис и отчет, который я получаю, это то, что имя пользователя / пароль не передается.
  • Я сам не могу отладить сообщение, потому что не могу показаться чтобы WCF взял тестовый сертификат у CXF.
  • Все отлично работало WCF для WCF, но это не то, что заказчик необходимо.

Я чувствую себя очень озадаченным. Спасибо за вашу помощь.

1 Ответ

0 голосов
/ 09 декабря 2011

Я не вижу установленного диагностического источника. Такие как это.

<system.diagnostics>
  <sources>
      <source name="System.ServiceModel.MessageLogging">
        <listeners>
                 <add name="messages"
                 type="System.Diagnostics.XmlWriterTraceListener"
                 initializeData="c:\logs\messages.svclog" />
          </listeners>
      </source>
    </sources>
</system.diagnostics>

Я надеюсь, что вы посмотрели эту статью msdn.

...