annotate servlet/src/digilib/io/XMLListLoader.java @ 266:81962224b18b

changed System.out for logger.debug
author robcast
date Mon, 11 Oct 2004 21:28:30 +0200
parents afe7ff98bb71
children 084ef7fbe420
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
1 /* XMLListLoader -- Load an XML list into a Hashtable
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
2
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
3 Digital Image Library servlet components
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
4
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
5 Copyright (C) 2001, 2002 Robert Casties (robcast@mail.berlios.de)
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
6
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
7 This program is free software; you can redistribute it and/or modify it
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
9 Free Software Foundation; either version 2 of the License, or (at your
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
10 option) any later version.
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
11
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
12 Please read license.txt for the full details. A copy of the GPL
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
13 may be found at http://www.gnu.org/copyleft/lgpl.html
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
14
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
15 You should have received a copy of the GNU General Public License
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
16 along with this program; if not, write to the Free Software
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
18
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
19 */
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
20
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
21 package digilib.io;
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
22
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
23 // JAXP packages
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
24 import java.io.IOException;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
25 import java.util.HashMap;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
26 import java.util.LinkedList;
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
27
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
28 import javax.xml.parsers.ParserConfigurationException;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
29 import javax.xml.parsers.SAXParser;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
30 import javax.xml.parsers.SAXParserFactory;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
31
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
32 import org.apache.log4j.Logger;
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
33 import org.xml.sax.Attributes;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
34 import org.xml.sax.SAXException;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
35 import org.xml.sax.SAXParseException;
140
c878ea574c29 Servlet Version 1.12b2
robcast
parents: 138
diff changeset
36 import org.xml.sax.helpers.DefaultHandler;
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
37
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
38 /** Loads a simple XML list into a HashMap.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
39 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
40 * The XML file has an outer <code>list_tag</code>. Every entry is an
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
41 * <code>entry_tag</code> with two attributes: the <code>key_att</code>
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
42 * key and the <code>value_att</code> value.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
43 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
44 * The file is read by the <code>loadURL</code> method, that returns a
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
45 * HashMap with the key-value pairs.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
46 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
47 * @author casties
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
48 */
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
49 public class XMLListLoader {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
50
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
51 private Logger logger = Logger.getLogger(this.getClass());
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
52 private String listTag = "list";
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
53 private String entryTag = "entry";
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
54 private String keyAtt = "key";
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
55 private String valueAtt = "value";
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
56
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
57 public XMLListLoader() {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
58 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
59
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
60 public XMLListLoader(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
61 String list_tag,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
62 String entry_tag,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
63 String key_att,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
64 String value_att) {
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
65 logger.debug("xmlListLoader("+list_tag+","+entry_tag+","+key_att+","+value_att+")");
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
66 listTag = list_tag;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
67 entryTag = entry_tag;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
68 keyAtt = key_att;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
69 valueAtt = value_att;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
70 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
71
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
72 /**
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
73 * inner class XMLListParser to be called by the parser
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
74 */
140
c878ea574c29 Servlet Version 1.12b2
robcast
parents: 138
diff changeset
75 private class XMLListParser extends DefaultHandler {
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
76
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
77 private HashMap listData;
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
78 private LinkedList tagSpace;
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
79
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
80 public HashMap getData() {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
81 return listData;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
82 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
83
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
84 // Parser calls this once at the beginning of a document
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
85 public void startDocument() throws SAXException {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
86 listData = new HashMap();
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
87 tagSpace = new LinkedList();
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
88 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
89
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
90 // Parser calls this for each element in a document
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
91 public void startElement(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
92 String namespaceURI,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
93 String localName,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
94 String qName,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
95 Attributes atts)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
96 throws SAXException {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
97 //System.out.println("<"+qName);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
98 // open a new namespace
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
99 tagSpace.addLast(qName);
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
100
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
101 // ist it an entry tag?
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
102 if (qName.equals(entryTag)) {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
103 // is it inside a list tag?
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
104 if ((listTag.length() > 0) && (!tagSpace.contains(listTag))) {
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
105 logger.error("BOO: Entry "
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
106 + entryTag
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
107 + " not inside list "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
108 + listTag);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
109 throw new SAXParseException(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
110 "Entry " + entryTag + " not inside list " + listTag,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
111 null);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
112 }
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
113 // get the attributes
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
114 String key = atts.getValue(keyAtt);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
115 String val = atts.getValue(valueAtt);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
116 if ((key == null) || (val == null)) {
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
117 logger.error("BOO: Entry "
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
118 + entryTag
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
119 + " does not have Attributes "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
120 + keyAtt
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
121 + ", "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
122 + valueAtt);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
123 throw new SAXParseException(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
124 "Entry "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
125 + entryTag
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
126 + " does not have Attributes "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
127 + keyAtt
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
128 + ", "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
129 + valueAtt,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
130 null);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
131 }
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
132 // add the values
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
133 //System.out.println("DATA: "+key+" = "+val);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
134 listData.put(key, val);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
135 }
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
136 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
137
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
138 public void endElement(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
139 String namespaceURI,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
140 String localName,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
141 String qName)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
142 throws SAXException {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
143 // exit the namespace
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
144 tagSpace.removeLast();
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
145 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
146
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
147 }
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
148
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
149 /**
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
150 * load and parse a file (as URL)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
151 * returns HashMap with list data
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
152 */
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
153 public HashMap loadURL(String path) throws SAXException, IOException {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
154 //System.out.println("loadurl ("+path+")");
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
155 // Create a JAXP SAXParserFactory and configure it
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
156 SAXParserFactory spf = SAXParserFactory.newInstance();
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
157 spf.setNamespaceAware(true);
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
158
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
159 SAXParser parser = null;
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
160 try {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
161 // Create a JAXP SAXParser
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
162 parser = spf.newSAXParser();
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
163
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
164 } catch (ParserConfigurationException e) {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
165 throw new SAXException(e);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
166 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
167
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
168 // create a list parser (keeps the data!)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
169 XMLListParser listParser = new XMLListParser();
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
170
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
171 // Tell the SAXParser to parse the XML document
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
172 parser.parse(path, listParser);
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
173
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
174 return listParser.getData();
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
175 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
176
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
177 }