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

Java XML parser executes each node twice

我尝试用在互联网上找到的 class 来解析 XML 文件。唯一的问题是它通过每个节点两次。第一次 return 实际值,第二次为 null。这使得最终值为空。这是解析器的代码 class:

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);


}

}

这是执行解析的服务器Slave:

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>

最后这就是我在控制台上得到的结果

首次解析

qname = 请求


Donnée du nœud 请求:


qname = ReqName


Donnée du nœud ReqName : LIST Fin de l'élément ReqName


Donnée du nœud ReqName :


qname = 目录


Donnée du nœud 导演:/home/abdou/Bureau Fin de l'élément Dir


Donnée du nœud 导演:


qname = 邮件地址


Donnée du nœud 邮件地址:abderrahmen.mrabet@edu.univ-paris13.fr Fin de l'élément MailAddress


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

Fin de l'élément 请求 Fin du 解析


可以清楚的看到他每个节点都经过了两次,他打印的secon值为null。

感谢您的帮助。

对于未来的观众。正如 potame 所说,这个错误是由于 characters(...) 事件没有被触发一次,它 "splits" char 数据。