首页 > 解决方案 > 捕获 svclog 文件的第二个 E2ETraceEvent

问题描述

我需要使用服务跟踪查看器找到标签 200,它看起来像这样!

<SOAP-ENV:Body xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="id-14799">
<ns2:SendInvoice xmlns:ns2="http://www.zadrwan.com/services/" xmlns:ns3="http://www.zadrwan.com/services/DocumentSendTo" xmlns:ns4="http://www.zadrwan.com/services/VersionRequest">                            
<ns2:Response>200</ns2:Response>
<ns2:Comments>Success!.</ns2:Comments>
</ns2:SendInvoice>

运行 web 服务时,会执行 Trace 并编写 E2ETraceEvent 第一个我不需要它,但第二个 E2ETraceEvent (request) 是我需要的,并且在哪里

我在这个页面上找到了一些代码monitoring-and-reading-svclog-file

我的代码是这样的:

 XmlReader reader = XmlReader.Create(stream, settings);
            while (reader.Read())
            {

                switch (reader.NodeType)
                {
                    case XmlNodeType.Element:

                        if (reader.Name == "E2ETraceEvent")
                        {

                            XmlReader subReader = reader.ReadSubtree();

                            while (subReader.Read())
                            {
                                switch (reader.NodeType)
                                {
                                    case XmlNodeType.Element:
                                        while (reader.Name == "Body")
                                        {
                                            Console.WriteLine(subReader.ReadOuterXml());
                                        } 

                                        break;
                                }
                            }

                        }
                        break;
                }
            }

我如何使用包含 n2 响应的标签捕获第二个?

标签: c#xmltrace

解决方案


您需要添加命名空间。就像是:

        using (XmlReader reader = XmlReader.Create(new StringReader(xml)))
        {
            XmlNamespaceManager nsmanager = new XmlNamespaceManager(reader.NameTable);
            nsmanager.AddNamespace("ns2", "http://www.zadrwan.com/services/");

            while (reader.Read())
            {
                switch (reader.Name)
                {
                    case "ns2:Response":
                        Console.WriteLine(reader.Name);
                        Console.WriteLine(reader.ReadInnerXml());
                        break;
                }
            }
        }

推荐阅读