Java - error java.lang.reflect.InvocationTargetException

 
Vista:
sin imagen de perfil
Val: 14
Ha aumentado su posición en 8 puestos en Java (en relación al último mes)
Gráfica de Java

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
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder