我在实现我的WCF消息拦截器时遇到了一些问题。基本上我正在访问正文内容并在节点集上执行xslt转换以对其进行alphabethicaly排序。
我已经测试了XSLT样式表,它没有任何问题。我将转换的结果写入MemoryStream对象,然后尝试从流内容中重新创建消息。
我使用StreamReader检查生成的流,或者将它加载到XmlDocument中,我可以看到它包含的xml,它是我对XSLT转换的预期结果。
当我尝试重新创建消息时,我的问题出现了!我基于流创建了一个XmlReader,并将其用作Message.CreateMessage(.....)的主体源;
我无法理解为什么我突然失去流中的“正确”内容,因为我可以检查它并在之前看到一些声明。
非常感谢帮助!
以下方法的完整代码:
public object AfterReceiveRequest(ref System.ServiceModel.Channels.Message request, IClientChannel channel, InstanceContext instanceContext)
{
MessageBuffer msgbuf = request.CreateBufferedCopy(int.MaxValue);
Message tmpMessage = msgbuf.CreateMessage();
XmlDictionaryReader xdr = tmpMessage.GetReaderAtBodyContents();
MemoryStream ms = new MemoryStream();
_compiledTransform.Transform(xdr,null,ms);
ms.Position = 0;
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(ms);
MemoryStream newStream = new MemoryStream();
xmlDoc.Save(newStream);
newStream.Position = 0;
//To debug contents of the stream
StreamReader sr = new StreamReader(newStream);
var temp = sr.ReadToEnd();
//At this point the XSLT tranforms has resulted in the fragment we want so all good!
XmlReaderSettings settings = new XmlReaderSettings();
settings.ConformanceLevel = ConformanceLevel.Fragment;
newStream.Position = 0;
XmlReader reader = XmlReader.Create(newStream,settings);
reader.MoveToContent();
//Reader seems to have lost the correct fragment!!! At least returned message does not contain correct fragment.
Message newMessage = Message.CreateMessage(request.Version, null, reader);
newMessage.Properties.CopyProperties(request.Properties);
request = newMessage;
return request;
}
答案 0 :(得分:0)
除非您尝试correlate state with the BeforeSendReply method,否则您应该返回null而不是请求引用。
答案 1 :(得分:0)
我认为您的代码适用于Griff。我刚刚将它插入到现有的IDispatchMessageInspector实现中,它生成了一个好的(转换的)消息。因此,我怀疑你的问题出在其他地方。
你如何确定'失去'正确的内容?检查转换后的消息是否可以在转换之前错误地阅读消息?