annotate common/src/main/java/digilib/util/XMLListLoader.java @ 1158:2ee261676828 default tip

better out-of-the box experience: * digilib works without config files using sensible defaults * new sample images folder used by default * config files moved to templates
author robcast
date Tue, 19 Feb 2013 17:32:25 +0100
parents 7779b37d1d05
children
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
590
69bc69381ac4 more work on stream input and more cleanup
robcast
parents: 536
diff changeset
21 package digilib.util;
1
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;
272
084ef7fbe420 Servlet version 1.21b3
robcast
parents: 181
diff changeset
27 import java.util.Map;
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
28
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
29 import javax.xml.parsers.ParserConfigurationException;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
30 import javax.xml.parsers.SAXParser;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
31 import javax.xml.parsers.SAXParserFactory;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
32
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
33 import org.apache.log4j.Logger;
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
34 import org.xml.sax.Attributes;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
35 import org.xml.sax.SAXException;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
36 import org.xml.sax.SAXParseException;
140
c878ea574c29 Servlet Version 1.12b2
robcast
parents: 138
diff changeset
37 import org.xml.sax.helpers.DefaultHandler;
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
38
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
39 /** Loads a simple XML list into a HashMap.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
40 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
41 * The XML file has an outer <code>list_tag</code>. Every entry is an
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
42 * <code>entry_tag</code> with two attributes: the <code>key_att</code>
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
43 * key and the <code>value_att</code> value.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
44 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
45 * The file is read by the <code>loadURL</code> method, that returns a
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
46 * HashMap with the key-value pairs.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
47 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
48 * @author casties
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 140
diff changeset
49 */
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
50 public class XMLListLoader {
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
51
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
52 private Logger logger = Logger.getLogger(this.getClass());
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
53 private String listTag = "list";
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
54 private String entryTag = "entry";
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
55 private String keyAtt = "key";
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
56 private String valueAtt = "value";
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
57
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
58 public XMLListLoader() {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
59 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
60
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
61 public XMLListLoader(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
62 String list_tag,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
63 String entry_tag,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
64 String key_att,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
65 String value_att) {
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
66 logger.debug("xmlListLoader("+list_tag+","+entry_tag+","+key_att+","+value_att+")");
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
67 listTag = list_tag;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
68 entryTag = entry_tag;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
69 keyAtt = key_att;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
70 valueAtt = value_att;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
71 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
72
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
73 /**
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
74 * inner class XMLListParser to be called by the parser
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
75 */
140
c878ea574c29 Servlet Version 1.12b2
robcast
parents: 138
diff changeset
76 private class XMLListParser extends DefaultHandler {
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
77
531
9cedd170b581 * PDF generation works now even with subdirectories
robcast
parents: 1
diff changeset
78 private Map<String, String> listData;
9cedd170b581 * PDF generation works now even with subdirectories
robcast
parents: 1
diff changeset
79 private LinkedList<String> tagSpace;
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
80
531
9cedd170b581 * PDF generation works now even with subdirectories
robcast
parents: 1
diff changeset
81 public Map<String, String> getData() {
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
82 return listData;
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
83 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
84
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
85 // Parser calls this once at the beginning of a document
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
86 public void startDocument() throws SAXException {
531
9cedd170b581 * PDF generation works now even with subdirectories
robcast
parents: 1
diff changeset
87 listData = new HashMap<String, String>();
9cedd170b581 * PDF generation works now even with subdirectories
robcast
parents: 1
diff changeset
88 tagSpace = new LinkedList<String>();
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
89 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
90
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
91 // Parser calls this for each element in a document
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
92 public void startElement(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
93 String namespaceURI,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
94 String localName,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
95 String qName,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
96 Attributes atts)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
97 throws SAXException {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
98 //System.out.println("<"+qName);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
99 // open a new namespace
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
100 tagSpace.addLast(qName);
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
101
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
102 // ist it an entry tag?
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
103 if (qName.equals(entryTag)) {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
104 // is it inside a list tag?
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
105 if ((listTag.length() > 0) && (!tagSpace.contains(listTag))) {
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
106 logger.error("BOO: Entry "
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
107 + entryTag
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
108 + " not inside list "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
109 + listTag);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
110 throw new SAXParseException(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
111 "Entry " + entryTag + " not inside list " + listTag,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
112 null);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
113 }
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
114 // get the attributes
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
115 String key = atts.getValue(keyAtt);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
116 String val = atts.getValue(valueAtt);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
117 if ((key == null) || (val == null)) {
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
118 logger.error("BOO: Entry "
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
119 + entryTag
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
120 + " does not have Attributes "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
121 + keyAtt
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
122 + ", "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
123 + valueAtt);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
124 throw new SAXParseException(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
125 "Entry "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
126 + entryTag
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
127 + " does not have Attributes "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
128 + keyAtt
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
129 + ", "
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
130 + valueAtt,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
131 null);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
132 }
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
133 // add the values
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
134 //System.out.println("DATA: "+key+" = "+val);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
135 listData.put(key, val);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
136 }
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
137 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
138
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
139 public void endElement(
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
140 String namespaceURI,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
141 String localName,
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
142 String qName)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
143 throws SAXException {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
144 // exit the namespace
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
145 tagSpace.removeLast();
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
146 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
147
88
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 /**
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
151 * load and parse a file (as URL)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
152 * returns HashMap with list data
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
153 */
531
9cedd170b581 * PDF generation works now even with subdirectories
robcast
parents: 1
diff changeset
154 public Map<String, String> loadURL(String path) throws SAXException, IOException {
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
155 //System.out.println("loadurl ("+path+")");
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
156 // Create a JAXP SAXParserFactory and configure it
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
157 SAXParserFactory spf = SAXParserFactory.newInstance();
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
158 spf.setNamespaceAware(true);
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
159
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
160 SAXParser parser = null;
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
161 try {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
162 // Create a JAXP SAXParser
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
163 parser = spf.newSAXParser();
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
164
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
165 } catch (ParserConfigurationException e) {
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
166 throw new SAXException(e);
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
167 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
168
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
169 // create a list parser (keeps the data!)
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
170 XMLListParser listParser = new XMLListParser();
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
171
138
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
172 // Tell the SAXParser to parse the XML document
d18b0ff52b07 *** empty log message ***
robcast
parents: 128
diff changeset
173 parser.parse(path, listParser);
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
174
88
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
175 return listParser.getData();
398d39ee1014 New version 1.8b4.
robcast
parents: 56
diff changeset
176 }
1
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
177
0ff3ede32060 Initial revision
robcast
parents:
diff changeset
178 }