Question Comment enregistrer le contenu du message WCF?


enter image description here

Je pensais que ce serait simple, mais je ne vois pas comment dire à WCF de consigner les corps de message. J'ai:

<system.diagnostics>
  <sources>
    <source name="System.ServiceModel" switchValue="Verbose">
      <listeners>
        <add type="System.Diagnostics.DefaultTraceListener" name="Default">
          <filter type="" />
        </add>
        <add type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.EntLibLoggingProxyTraceListener,Microsoft.Practices.EnterpriseLibrary.Logging"
          name="traceListener">
          <filter type="" />
        </add>
      </listeners>
    </source>
  </sources>
</system.diagnostics>
<system.serviceModel>
   <diagnostics>
     <messageLogging logEntireMessage="true" logMalformedMessages="true"
       logMessagesAtServiceLevel="true" logMessagesAtTransportLevel="false" />
   </diagnostics>
   ...etc..,
   ...etc...
</system.Model>
<loggingConfiguration name="" tracingEnabled="true" defaultCategory="General">
   <listeners>
     <add fileName="_trace-xml.log"
                listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.XmlTraceListenerData,Microsoft.Practices.EnterpriseLibrary.Logging"
                traceOutputOptions="None"
                type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.XmlTraceListener,Microsoft.Practices.EnterpriseLibrary.Logging"
        name="XML Trace Listener" />      
     ...etc... other listeners
  </listeners>
  ...etc...
</loggingConfiguration>

Mais tout ce que je reçois est du contenu, pas du corps du message. Que dois-je changer pour enregistrer le contenu du message?


19
2017-11-08 13:37


origine


Réponses:


Si vous avez besoin de corps de message, vous devrez les capturer vous-même, par programme. Utilisez un comportement de service pour installer un inspecteur de messages et capturer des messages dans votre implémentation de IDispatchMessageInspector ou IClientMessageInspector.


0
2017-11-08 14:29



Juste suivre cette description fonctionne parfaitement pour moi: http://msdn.microsoft.com/en-us/library/ms730064.aspx

<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>

<system.serviceModel>
<diagnostics>
<messageLogging 
     logEntireMessage="true" 
     logMalformedMessages="false"
     logMessagesAtServiceLevel="true" 
     logMessagesAtTransportLevel="false"
     maxMessagesToLog="3000"
     maxSizeOfMessageToLog="2000"/>
</diagnostics>
</system.serviceModel>

Pas besoin d'écrire du code pour ça ...


29
2017-11-08 22:11



J'ai trouvé un problème de versioning. Lorsque le projet de service WCF a été créé avec .Net 3.5, j'ai vu le corps du message complet dans l'outil de visualisation. Construit contre .Net 4.0, je n'ai vu aucun corps de message.


3
2017-11-17 13:51



Essayer http://www.csharptutorial.in/12/csharp-net-wcf-how-to-enable-wcf-tracing-and-messagelogging et installez logMessagesAtTransportLevel = "true". Dans votre fichier journal, vous pouvez trouver <s:Body> Mots clés. Recherchez le texte près d'eux. Plus tard, vous pouvez ajouter un nouveau "XmlListener" et trouver le corps du message dans un format plus flexible.


1
2017-10-10 10:33