-2

In the method readAll() I got a NullPointerException on my Connection but why, and how could I change that?

If I test it with the main class everything worked well, but if I do the same on a server (Webserver - local) it throws a NullPointerException.

Here is my ConnectionManager class:

public class ConnectionManager {

    private volatile static ConnectionManager connectionManager = null;
    private Connection connection = null;

    private ConnectionManager() throws SQLException, ClassNotFoundException, InstantiationException, IllegalAccessException {
        DBProperties properties = DBProperties.getInstance();

        String url = properties.getStringProperty("databaseURL") + properties.getStringProperty("pathToDB") + properties.getStringProperty("urlSettings");
        String user = properties.getStringProperty("user");
        String passwort = properties.getStringProperty("password");

        try { // load driver
            Class.forName(properties.getStringProperty("dbDriver")).newInstance();
            connection = DriverManager.getConnection(url, user, passwort);
        } catch (SQLException ex) {
            Logger.getLogger(ConnectionManager.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

    public synchronized static ConnectionManager getInstance() throws SQLException {
        if (connectionManager == null) {
            try {
                connectionManager = new ConnectionManager();
            } catch (Exception ex) {
                Logger.getLogger(ConnectionManager.class.getName()).log(Level.SEVERE, null, ex);
            }
        }
        return connectionManager;
    }

    public Connection getConnection() {
        return connection;
    }

    public static void closeConnection() {
        //close the connection only if there is a instance
        //--> closeConnection() can always be called. 
        //(e.g. if non JDBC-Dao's are used  --> ConnectionManager is not instantiated)
        if (connectionManager != null) {
            try {
                connectionManager.connection.close();
            } catch (SQLException ex) {
                Logger.getLogger(ConnectionManager.class.getName()).log(Level.SEVERE, null, ex);
            }
        }
    }

}

And here is my JDBC class which throws the exception:

@Override
public List<User> readAll() {

    List<User> userList = new LinkedList<>();

    try (Statement statement = ConnectionManager.getInstance().getConnection().createStatement()){

        ResultSet result = statement.executeQuery("select * from Users");

        while(result.next()){
            int userID = Integer.valueOf( result.getString("UserID") );
            String firmenname = result.getString("Firmenname");
            boolean firma = Boolean.getBoolean( result.getString("Firma") );
            String vorname = result.getString("Vorname");
            String nachname = result.getString("Nachname");;
            int rollenID = Integer.valueOf( result.getString("RollenID") );
            String email = result.getString("Email");;
            String passwort = result.getString("Passwort");;
            String telefonnummer = result.getString("Telefonnummer");;
            String adresse = result.getString("Adresse");;
            int plz = Integer.valueOf( result.getString("PLZ") );
            String ort = result.getString("Ort");;

            userList.add( new User(userID, firmenname, firma, vorname, nachname, new Rolle(rollenID, "???", false, false, false, false, false, false), email, passwort, telefonnummer, adresse, plz, ort) );

        }
    } catch (SQLException ex) {
        Logger.getLogger(UserJDBCDAO.class.getName()).log(Level.SEVERE, null, ex);
    }

    return userList;
}

And here is the Exception

java.lang.NullPointerException
at at.htlpinkafeld.langoscharly.dao.jdcb.UserJDBCDAO.readAll(UserJDBCDAO.java:68)
at at.htlpinkafeld.langoscharly.dao.factory.DAOFactory.readAllUser(DAOFactory.java:123)
at at.htlpinkafeld.langoscharly.service.LangosCharlyService.getUsers(LangosCharlyService.java:30)
at at.htlpinkafeld.langoscharly.gui.UserBean.getUsers(UserBean.java:27)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at javax.el.BeanELResolver.getValue(BeanELResolver.java:97)
at com.sun.faces.el.DemuxCompositeELResolver._getValue(DemuxCompositeELResolver.java:176)
at com.sun.faces.el.DemuxCompositeELResolver.getValue(DemuxCompositeELResolver.java:203)
at org.apache.el.parser.AstValue.getValue(AstValue.java:169)
at org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:184)
at com.sun.faces.facelets.el.TagValueExpression.getValue(TagValueExpression.java:109)
at javax.faces.component.ComponentStateHelper.eval(ComponentStateHelper.java:194)
at javax.faces.component.ComponentStateHelper.eval(ComponentStateHelper.java:182)
at javax.faces.component.UIData.getValue(UIData.java:732)
at org.primefaces.component.datatable.DataTable.getValue(DataTable.java:1002)
at org.primefaces.component.api.UIData.getDataModel(UIData.java:629)
at javax.faces.component.UIData.getRowCount(UIData.java:356)
at org.primefaces.component.datatable.DataTableRenderer.encodeTbody(DataTableRenderer.java:762)
at org.primefaces.component.datatable.DataTableRenderer.encodeTbody(DataTableRenderer.java:744)
at org.primefaces.component.datatable.DataTableRenderer.encodeRegularTable(DataTableRenderer.java:258)
at org.primefaces.component.datatable.DataTableRenderer.encodeMarkup(DataTableRenderer.java:220)
at org.primefaces.component.datatable.DataTableRenderer.encodeEnd(DataTableRenderer.java:84)
at javax.faces.component.UIComponentBase.encodeEnd(UIComponentBase.java:919)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1863)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1859)
at javax.faces.component.UIComponent.encodeAll(UIComponent.java:1859)
at com.sun.faces.application.view.FaceletViewHandlingStrategy.renderView(FaceletViewHandlingStrategy.java:456)
at com.sun.faces.application.view.MultiViewHandler.renderView(MultiViewHandler.java:133)
at com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:120)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:219)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:647)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:291)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:217)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:142)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:616)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:518)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1091)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:673)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1500)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1456)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)
khelwood
  • 55,782
  • 14
  • 81
  • 108
Coolar
  • 27
  • 5
  • I rarely use plain JDBC but you might have to register the driver with the DriverManager - you're just creating a new instance of the driver but don't use that instance at all (unless the driver has some self-registration code which I don't know). I further assume you don't get any exception before the one you've posted and that you debugged your code to verify everything ran as expected. – Thomas Nov 05 '18 at 16:42
  • why are there two semicolons after some codes.? Example `String nachname = result.getString("Nachname");;` – Mustafa Çil Nov 05 '18 at 16:43
  • **Use a debugger**, also specifically check this line `connection = DriverManager.getConnection(url, user, passwort);` and see if it actually gets a connection. – xtratic Nov 05 '18 at 16:43
  • You have no other exceptions besides that one? I guess you do... – Antoniossss Nov 05 '18 at 16:45
  • @Antoniossss ... Or other error traces. – Little Santi Nov 05 '18 at 16:46
  • 1
    You catch and log exception, and then continue on as if nothing happens, leaving fields initialized with `null`... – Mark Rotteveel Nov 06 '18 at 10:06
  • I only get a NullPoinerExceptrion when I call it with a local apache server, when I call it manually I have a connection. – Coolar Nov 06 '18 at 14:26

1 Answers1

2

Most likely you have a SQLException which you only log in:

try { // load driver
    Class.forName(properties.getStringProperty("dbDriver")).newInstance();
    connection = DriverManager.getConnection(url, user, passwort);
} catch (SQLException ex) {
    Logger.getLogger(ConnectionManager.class.getName()).log(Level.SEVERE, null, ex);
}

There is no reason to handle SQLException here. You are not implementing the re-connection logic anywhere in your ConnectionManager, if you don't have a valid connection your application doesn't work. You should re-throw it and let you application exit:

} catch (SQLException ex) {
    Logger.getLogger(ConnectionManager.class.getName()).log(Level.SEVERE, null, ex);
    throw ex;
}
Karol Dowbecki
  • 43,645
  • 9
  • 78
  • 111
  • 1
    It might even be better not to catch the exception at all here. Just let it propagate to the caller. It's opinion-based but see https://stackoverflow.com/a/6640029/638028 for a reasoned argument. – Klitos Kyriacou Nov 05 '18 at 17:09
  • It was not an SQL Exception it was a completely different thing my ConnectionMangert only worked for local Operations and I used it for a Web Application. – Coolar Feb 14 '19 at 13:30