Java XML解析器对每个节点执行两次

Java XML解析器对每个节点执行两次,java,xml,parsing,sax,Java,Xml,Parsing,Sax,我尝试用在internet上找到的类解析XML文件。唯一的问题是它经过每个节点两次。第一次返回实际值,第二次返回null。这使得最终值为空。以下是解析器类的代码: public class MyXMLHandler extends DefaultHandler{ private String node = null; int i = 0; int j = 0; int k = 0; boolean cont = true; public void startDocument(

我尝试用在internet上找到的类解析XML文件。唯一的问题是它经过每个节点两次。第一次返回实际值,第二次返回null。这使得最终值为空。以下是解析器类的代码:

public class MyXMLHandler extends DefaultHandler{
private String node = null;
int i = 0;
   int j = 0;
   int k = 0;
   boolean cont = true;

public void startDocument() throws SAXException {
    System.out.println("Début du parsing");
}

public void startElement(String namespaceURI, String lname, String qname, Attributes attrs) throws SAXException {
    System.out.println("---------------------------------------------");
    System.out.println("qname = " + qname);
    node = qname;

}

public void endElement(String uri, String localName, String qName)throws SAXException{
    System.out.println("Fin de l'élément " + qName);      
    }

public void endDocument() throws SAXException {
    System.out.println("Fin du parsing");
}


public void characters(char[] data, int start, int end){  
   System.out.println("***********************************************");
   String rep ="";
   String str = new String(data, start, end);


   System.out.println("Donnée du nœud " + node + " : " + str);


}
}

这是执行解析的服务器从机:

public class ServerEsclave implements Runnable{


private final Socket socket;
private  ServerSocket serverSocket;
private ServerMaitre serverMaitre;
ServerEsclave(Socket socket, ServerSocket serveur){
    this.socket = socket;
    this.serverSocket = serveur;
}

ServerEsclave(Socket socket, ServerMaitre serverMaitre) {
    // TODO Auto-generated constructor stub
    this.socket = socket;
    this.serverMaitre = serverMaitre;
}

@Override
public void run() {
    try {
        BufferedReader input = new BufferedReader(
                new InputStreamReader(socket.getInputStream(), "8859_1"), 1024);
        StringBuffer sb = new StringBuffer();
        InputStream ch = socket.getInputStream();
        //sb.append(input.readLine());
        //System.out.println(sb);
        //String[] commande = sb.toString().split(" ");
        try {
            SAXParserFactory factory = SAXParserFactory.newInstance();
            SAXParser parser = factory.newSAXParser();

            parser.parse(ch, new MyXMLHandler());

            }catch (DOMException e) {
                e.printStackTrace();
            } catch (ParserConfigurationException e) {
                e.printStackTrace();
            } catch (TransformerFactoryConfigurationError e) {
                e.printStackTrace();
            } catch (SAXException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        catch(IOException e) {System.out.println(e);}
        finally {
            try { if(socket != null) socket.close();}
            catch(IOException e) {}
        }
    }
}
我要分析的XML代码:

<?xml version="1.0" encoding="iso-8859-1"?>
<Request>
   <ReqName> LIST </ReqName>
   <Dir>/home/abdou/Bureau</Dir>   
   <MailAddress>abderrahmen.mrabet@edu.univ-paris13.fr</MailAddress>
</Request>

列表
/家庭/阿布杜/局
阿布德拉曼。mrabet@edu.univ-巴黎13.fr
最后,这是我在控制台上看到的

迪布杜 qname=请求


Donnée du nœud请求:


qname=ReqName


Donnée du nœud ReqName:列表 财务需求名称


Donnée du nœud要求姓名:


qname=Dir


唐尼·杜努德·迪尔(Donnée du nœud Dir):/家/阿布杜/局 财政司司长


唐尼·杜努德·迪尔:


qname=邮件地址


Donnée du nœud邮寄地址:Abderraman。mrabet@edu.univ-巴黎13.fr Fin de lélément邮件地址


Donnée du nœud邮寄地址:

财务申报单 findu解析


您可以清楚地看到,他通过每个节点传递了两次,并且他打印的secon值为null


谢谢你的帮助

面向未来的观众。正如potame所说,这个bug是由于characters(…)事件没有触发一次,它会“拆分”字符数据。

这是因为
characters(…)
事件没有触发一次,它会“拆分”字符数据。例如,您应该在
startElement()
中打印它。没有理由相信每个元素只包含一组字符。