无法获取xml文件中具有name =“debitRequest”的父节点的子节点名称

时间:2013-03-19 14:12:10

标签: java xml xml-parsing

我正在使用xml文件“SavedWSDL.txt”,下面给出了部分内容......

  ...
<wsdl:message name="LookUpTransactionResponse">
<wsdl:part name="LookUpTransactionReturn" type="impl:ArrayOf_xsd_anyType"/>
</wsdl:message>
<wsdl:message name="LookUpTransactionRequest"></wsdl:message>
<wsdl:message name="creditResponse">
<wsdl:part name="creditReturn" type="xsd:int"/>
</wsdl:message>
<wsdl:message name="creditRequest">
<wsdl:part name="amount" type="xsd:float"/>
<wsdl:part name="password" type="xsd:string"/>
</wsdl:message>
<wsdl:message name="debitRequest">
<wsdl:part name="amount" type="xsd:float"/>
<wsdl:part name="password" type="xsd:string"/>
</wsdl:message>
<wsdl:message name="debitResponse">
<wsdl:part name="debitReturn" type="xsd:int"/>
</wsdl:message>
    ...

我编写了下面给出的java代码,应该使用什么来获取名为“debitRequest”的wsdl:message标签的子节点名称

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class Ex2 {

    public static void main(String[] args) {
        try {
            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
            DocumentBuilder db = dbf.newDocumentBuilder();
            Document doc = db.parse("D:/SavedWSDL.txt");
            doc.getDocumentElement().normalize();

            NodeList nodelist = doc.getElementsByTagName("wsdl:message");
            //System.out.println("No. of Nodes: "+nodelist.getLength());

            for(int i=0;i<nodelist.getLength();i++){
                Node node=nodelist.item(i);
                String valueOfTag=node.getAttributes().getNamedItem("name").getNodeValue();
                if(valueOfTag.equalsIgnoreCase("debitrequest")){
                    if(node.hasChildNodes()){
                        NodeList childNList=node.getChildNodes();
                        //System.out.println("No. of Childs: "+node.getChildNodes().getLength());
                        //System.out.println(node.getAttributes().getNamedItem("name").getNodeValue());
                    }
                    else{
                        System.out.println("NO CHILD FOUND for: "+valueOfTag);
                    }
                }   
            }
        } catch(Exception io) {
            io.printStackTrace();
        } 
    }
    }

1 个答案:

答案 0 :(得分:5)

在给定的XML中,节点之间存在Text(不可见):

<wsdl:message name="debitRequest"> <-- Text
<wsdl:part name="amount" type="xsd:float"/> <-- Text
<wsdl:part name="password" type="xsd:string"/> <-- Text
</wsdl:message>

这就是为什么名为debitRequest的节点有5个子节点(文本,节点,文本,节点,文本)

新ChildNode的NodeType为1,Text的NodeType为3:

node.getNodeType() //1 is ChildNode, 3 is Text

因此,在拥有节点并且想要获取其所有子节点后,您应该循环它并检查类型。然后你可以检查属性。

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

public class Ex2 {

    public static void main(String[] args) {
        try {
            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
            DocumentBuilder db = dbf.newDocumentBuilder();
            Document doc = db.parse("testxml.xml");
            doc.getDocumentElement().normalize();

            NodeList nodelist = doc.getElementsByTagName("wsdl:message");
            //System.out.println("No. of Nodes: "+nodelist.getLength());

            for(int i=0;i<nodelist.getLength();i++){
                Node node=nodelist.item(i);
                String valueOfTag=node.getAttributes().getNamedItem("name").getNodeValue();
                if(valueOfTag.equalsIgnoreCase("debitrequest")){
                    if(node.hasChildNodes()){
                        NodeList childNList=node.getChildNodes();
                        for(int j = 0; j < childNList.getLength();j++)
                        {
                            Node n = childNList.item(j);
                            if(n.getNodeType() == 1) //NodeType 1 = Next XML Node
                            {
                                String nvalue = n.getAttributes().getNamedItem("name").getNodeValue();
                                System.out.println(nvalue);
                            }
                            /*if(n.getAttributes() != null){
                                String s = n.getAttributes().getNamedItem("name").getNodeValue();
                                System.out.println(s);
                            }*/
                        }
                        System.out.println(childNList.getLength());

                    }
                    else{
                        System.out.println("NO CHILD FOUND for: "+valueOfTag);
                    }
                }   
            }
        } catch(Exception io) {
            io.printStackTrace();
        } 
    }
    }

如果它为空,您还可以循环您的孩子并检查每个Node.getAttributes()。如果不是,您可以在属性中搜索"name"并继续。第二种方式也显示在我的代码中,但已注释掉。其中:if(n.getAttributes() != null){评论。