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 数据。
我尝试用在互联网上找到的 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 数据。