使用XmlDictionaryReader从Message中获取值

时间:2016-08-02 19:58:30

标签: c# .net xml wcf

我需要从WCF消息中获取值。我的消息在调试器中具有以下值:

<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
  <s:Header>
    <Action s:mustUnderstand="1" xmlns="http://schemas.microsoft.com/ws/2005/05/addressing/none">http://tempuri.org/IBrokerService/SaveAndPrint</Action>
  </s:Header>
  <s:Body>
    <SaveAndPrint xmlns="http://tempuri.org/">
      <contract xmlns:d4p1="http://schemas.datacontract.org/2004/07/BrokerService.Contracts" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
        <d4p1:ContainerHistoryContracts i:nil="true" />
        <!--Lots of nodes removed for brevity-->
        <d4p1:CurrentBagId>123456</d4p1:CurrentBagId>
        <!--Lots more nodes removed for brevity-->
        <d4p1:WorkStation>TheNeededValue</d4p1:WorkStation>
      </contract>
    </SaveAndPrint>
  </s:Body>
</s:Envelope>

但是尽可能地尝试,我不能使用XmlDictionaryReader来获取d4p1:WorkStation值。任何人都知道如何使用XmlDictionaryReader做到这一点?

注意:我尝试使用TypedMessageConverter,但生成的clasess没有MessageContract的属性(但它们确实有DataContract

更新:我所拥有的不起作用。但是,如果你想看到它,它就是:

        // Load the message into an xml doc
        var navigator = buffer.CreateNavigator();
        MemoryStream memoryStream = new MemoryStream();
        XmlWriter xmlWriter = XmlWriter.Create(memoryStream);
        navigator.WriteSubtree(xmlWriter);
        xmlWriter.Flush();
        xmlWriter.Close();
        memoryStream.Position = 0;

        XDocument xdoc = XDocument.Load(XmlReader.Create(memoryStream));
        var workstationElement =
            xdoc.Descendants(XName.Get("StringValue",
                @"/s:Envelope[@xmlns:s=""http://schemas.xmlsoap.org/soap/envelope/""]/s:Body/SaveAndPrint[@xmlns=""http://tempuri.org/""]/contract[@xmlns:d4p1=""http://schemas.datacontract.org/2004/07/BrokerService.Contracts""]/d4p1:WorkStation"));

1 个答案:

答案 0 :(得分:0)

试试xml linq

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Linq;


namespace ConsoleApplication6
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XDocument doc = XDocument.Load(FILENAME);
            //using unique keys
            Dictionary<string, string> dict1 = doc.Descendants().Where(x => x.Name.LocalName == "contract").FirstOrDefault().Elements()
                .GroupBy(x => x.Name.LocalName, y => ((string)y).Trim())
                .ToDictionary(x => x.Key, y => y.FirstOrDefault());
            //when there are duplicate keys
            Dictionary<string, List<string>> dict2 = doc.Descendants().Where(x => x.Name.LocalName == "contract").FirstOrDefault().Elements()
                .GroupBy(x => x.Name.LocalName, y => ((string)y).Trim())
                .ToDictionary(x => x.Key, y => y.ToList());


        }
    }
}