You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Describe the bug
I have the same issue as described at https://microsoft.public.dotnet.framework.webservices.narkive.com/n9xIRs39/modified-message-body-in-beforesendrequest-iclientmessagein-is-e. Calling any such overload invariably produces ...stream... where stream is localized into what the runtime believes to be the culture of the machine instead of the body of the message. Now, I tried to follow the tip left on that page and create my own Message class overriding OnWriteBodyContents(XmlDictionaryWriter writer) only to find out that it is NOT called by WCF at all. However, somehow it now outputs just ... in the same place.
To Reproduce
publicclassCorrectorInspector:IClientMessageInspector{privateclassMyMessage:Message{privateXmlReaderxmlReader1;privateMessagerequest;publicMyMessage(XmlReaderxmlReader1,Messagerequest){this.xmlReader1=xmlReader1;this.request=request;}publicoverrideMessageHeadersHeaders=>this.request.Headers;publicoverrideMessagePropertiesProperties=>this.request.Properties;publicoverrideMessageVersionVersion=>this.request.Version;protectedoverridevoidOnWriteBodyContents(XmlDictionaryWriterwriter){// Breakpoints are not hit.var_reader=this.xmlReader1;using(_reader){vartype=_reader.MoveToContent();while(!_reader.EOF&&type!=XmlNodeType.EndElement){if(type!=XmlNodeType.Element)thrownewInvalidOperationException();writer.WriteNode(_reader,false);type=_reader.MoveToContent();}}}}privatestaticreadonlyXNamespaceurn="urn:service";privatestaticreadonlyXNamespaceenv="http://schemas.xmlsoap.org/soap/envelope/";publicvoidAfterReceiveReply(refMessagereply,objectcorrelationState){}publicobject?BeforeSendRequest(refMessagerequest,IClientChannelchannel){varmsgbuf=request.CreateBufferedCopy(int.MaxValue);usingvartmpMessage=msgbuf.CreateMessage();usingvarms=newMemoryStream();usingvarwriter=XmlWriter.Create(ms,newXmlWriterSettings{OmitXmlDeclaration=true,NamespaceHandling=NamespaceHandling.OmitDuplicates});tmpMessage.WriteMessage(writer);writer.Flush();ms.Position=0;varxml=XDocument.Load(ms);xml.Root!.Add(newXAttribute(XNamespace.Xmlns+"urn",urn));varheader=xml.Root.Element(env+"Header")!;header.RemoveNodes();varbody=xml.Root.Element(env+"Body")!;body.RemoveAttributes();varaction=(XElement)body.FirstNode!;action.RemoveAttributes();action.Name=urn+action.Name.LocalName;foreach(varparaminaction.Elements()){param.Name=param.Name.LocalName;param.RemoveAttributes();}varnewMessage=newMyMessage(xml.CreateReader(),request);// Previously the above line was//var newRequest = Message.CreateMessage(xml.CreateReader(), int.MaxValue, request.Version);//newMessage.Headers.CopyHeadersFrom(oldMessage);//newRequest.Properties.CopyProperties(request.Properties);request=newMessage;// Breakpoint at this line reveals upon inspection of `newMessage` that the body tag has the unexpected value.returnnull;}}
Expected behavior
The message body, as a part of the whole message, is correctly replaced with the new XML.
Did you find any way around this issue? I've been blocked by the same problem and have been unable to figure out any method to get around the message body containing "... stream ..."
"... stream ..." is a placeholder that is shown when the message is being streamed (TransferMode.Streamed) and thus not in memory as a whole. Only when the complete message is stored in memory (TransferMode.Buffered) do you have access to the complete message.
TransferMode is a property on your binding. I think what you have should work but you might need to change your binding to (TransferMode.Streamed) on client/server.
If you don't want to see "... stream ..." try to buffer (TransferMode.Buffered) your newly created message before returning it:
Describe the bug
I have the same issue as described at https://microsoft.public.dotnet.framework.webservices.narkive.com/n9xIRs39/modified-message-body-in-beforesendrequest-iclientmessagein-is-e. Calling any such overload invariably produces
...stream...
wherestream
is localized into what the runtime believes to be the culture of the machine instead of the body of the message. Now, I tried to follow the tip left on that page and create my ownMessage
class overridingOnWriteBodyContents(XmlDictionaryWriter writer)
only to find out that it is NOT called by WCF at all. However, somehow it now outputs just...
in the same place.To Reproduce
Expected behavior
The message body, as a part of the whole message, is correctly replaced with the new XML.
Screenshots
I can do on request.
Additional context
The current behavior might be by design. https://learn.microsoft.com/en-us/dotnet/api/system.servicemodel.channels.message.createmessage?view=net-8.0-pp&devlangs=csharp&f1url=%3FappId%3DDev17IDEF1%26l%3DEN-US%26k%3Dk%28System.ServiceModel.Channels.Message.CreateMessage%29%3Bk%28DevLang-csharp%29%26rd%3Dtrue#system-servicemodel-channels-message-createmessage(system-xml-xmlreader-system-int32-system-servicemodel-channels-messageversion) remarks that it reads up to the body of the message. However, it doesn't explain how are we supposed to provide the body of the message then, neither there is any API that I could find myself for that, and all my Internet search results say in unison that this is how you change the message in an inspector w/o mentioning this pitfall, nor can I see how is outputting the literal string of
...stream...
(localized) in the modified response is helpful, and the other overloads taking anXml(...)Reader
instance do not have this note, but are still affected all the same. Either way, there is an issue to be resolved.I have tried many different combinations of streams and writers in every overload.
The text was updated successfully, but these errors were encountered: