error java.lang.reflect.InvocationTargetException
Publicado por juan (8 intervenciones) el 17/04/2018 23:03:30
Estoy intentando hacer que el resultado de una búsqueda me la pase a XML para después en la respuesta al cliente interpretarlo e imprimirlo de manera agradable. Ahora mi problema en la esta función es que estoy intentando usar Documet Builder para realizar la acción, pero he investigado y no se porque me da ese error, aparentemente debería funcionar.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
public String getMateria() {
Conexion c = new Conexion();
Connection cn = c.Conectar();
List<Materia> materia = null;
Statement st;
String output = "";
try {
st = cn.createStatement();
ResultSet rs = st.executeQuery("select * from asignaturas");
materia = new ArrayList<>();
DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder;
docBuilder = docFactory.newDocumentBuilder();
Document doc = docBuilder.newDocument();
Element rootElement = doc.createElement("materias");
doc.appendChild(rootElement);
while (rs.next()) {
materia.add(new Materia(rs.getInt(1), rs.getString(2), rs.getString(3), rs.getString(4)));
Element materia_1 = doc.createElement("materia");
Element cod_materia = doc.createElement("codigo");
Element nombre_materia = doc.createElement("nombre");
Element desc_materia = doc.createElement("descripcion");
cod_materia.appendChild(doc.createTextNode(rs.getString(2)));
nombre_materia.appendChild(doc.createTextNode(rs.getString(3)));
desc_materia.appendChild(doc.createTextNode(rs.getString(4)));
materia_1.appendChild(cod_materia);
materia_1.appendChild(nombre_materia);
materia_1.appendChild(desc_materia);
rootElement.appendChild(materia_1);
}
TransformerFactory tf = TransformerFactory.newInstance();
Transformer transfer = tf.newTransformer();
StringWriter write = new StringWriter();
transfer.transform(new DOMSource(doc), new StreamResult(write));
output = write.getBuffer().toString().replaceAll("\n|\r", "");
} catch (SQLException | ParserConfigurationException ex) {
Logger.getLogger(NewWebServiceMaterias.class.getName()).log(Level.SEVERE, null, ex);
} catch (TransformerConfigurationException ex) {
Logger.getLogger(NewWebServiceMaterias.class.getName()).log(Level.SEVERE, null, ex);
} catch (TransformerException ex) {
Logger.getLogger(NewWebServiceMaterias.class.getName()).log(Level.SEVERE, null, ex);
}
return output;
}
Valora esta pregunta
0