In Visual Studio 2010 I get an error which tells me the first 1024 bytes of a response from a WCF
service when consumed, but no more.
I would really like to see the entire response so I can work out what is going wrong, where can I get this info from? Is there a way of logging the full text of an error or are they all limited by the 1024 byte rule?
How to View more than 1024 bytes of a wcf response when an error occurs in Visual Studio 2010?
2 Answers
Answers 1
If you are doing this in debugging mode, where you have the exact steps pre-identified - you could try if setting maxReceivedMessageSize
to a large value helps.
As the description says on the docs:
maxReceivedMessageSize
A positive integer that specifies the maximum message size, in bytes, including headers, that can be received on a channel configured with this binding. The sender of a message exceeding this limit will receive a SOAP fault. The receiver drops the message and creates an entry of the event in the trace log. The default is 65536.
In your case, it might have been set to a lower value.
You could also check if the maxBufferPoolSize
has been set correctly - it seems that only one buffer worth of 1024 bytes are being transmitted back, which is possible if someone set the pool size as 1 instead of default 512.
Answers 2
Updated:
Use SvcConfigEditor.exe tool for tracing and logging need to be enabled in WCF configuration (app.config or web.config). Or you can use this SvcTraceViewer.exe tool for viewing the large XML's file.
For instance, you can below web.config settings for initializeData
attribute of the tracelistener
.
<system.serviceModel> <diagnostics> <messageLogging logEntireMessage="true" logMalformedMessages="true" logMessagesAtServiceLevel="true" logMessagesAtTransportLevel="true" /> </diagnostics> </system.serviceModel> <system.diagnostics> <sources> <source name="System.ServiceModel" switchValue="Information, ActivityTracing" propagateActivity="true"> <listeners> <add name="traceListener" type="System.Diagnostics.XmlWriterTraceListener" initializeData="C:\Temp\SvcLog\Traces.svclog" /> </listeners> </source> </sources> </system.diagnostics>
- Source is here.
0 comments:
Post a Comment