Erro ao acessar o banco

Eu estou fazendo um trabalho que eh um Almoxarifado de produtos.

Estou conseguindo cadastrar perfeitamente um produto no banco de dados.
Um produto tem Nome e quantidade.

Tenho operações de entrada e saída desses produtos.
entrada = somar o produto e fazer uma update no banco com a nova qtd.
saida = subtrair o produto e fazeruma update no banco.

qnd eu vou realizar uma entrada está dando o seguinte erro:

Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
        at DAO.DAOProduto.MontarProduto(DAOProduto.java:70) // o metodo MontarProduto está laH em baixo
        at telas.Entrada.jButton1ActionPerformed(Entrada.java:275)
        at telas.Entrada.access$000(Entrada.java:22)
        at telas.Entrada$1.actionPerformed(Entrada.java:78)
        at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)
        at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318)
        at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)
        at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)
        at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)
        at java.awt.Component.processMouseEvent(Component.java:6038)
        at javax.swing.JComponent.processMouseEvent(JComponent.java:3260)
        at java.awt.Component.processEvent(Component.java:5803)
        at java.awt.Container.processEvent(Container.java:2058)
        at java.awt.Component.dispatchEventImpl(Component.java:4410)
        at java.awt.Container.dispatchEventImpl(Container.java:2116)
        at java.awt.Component.dispatchEvent(Component.java:4240)
        at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4322)
        at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3986)
        at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3916)
        at java.awt.Container.dispatchEventImpl(Container.java:2102)
        at java.awt.Window.dispatchEventImpl(Window.java:2429)
        at java.awt.Component.dispatchEvent(Component.java:4240)
        at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)
        at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:273)
        at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:183)
        at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:173)
        at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:168)
        at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:160)
        at java.awt.EventDispatchThread.run(EventDispatchThread.java:121)

a minha ação do botão eh essa:

       String data = jTextFieldEntradaData.getText(); //data da entrada
       String nomeP = (String) jComboBoxEntradaProduto.getSelectedItem(); // nome do produto que já eh carregado no JcomboBox direto do banco.
       int qtd = Integer.parseInt(jTextFieldEntradaQtd.getText()); //a quantidade da entrada desse produto
       
       
       DAOProduto dp = new DAOProduto(); // 
       Produto produto = dp.MontarProduto(nomeP); // com isso eu monto um produto pelo nome passado no JcomboBox
       
       EntradaProduto e = new EntradaProduto(data,produto,qtd); // crio uma entrada passando a data, produto e a qtd
       if(e.Update()== true){ // depois de montar o produto eu atualizo ele no banco com esse metodo
           DAOEntrada de = new DAOEntrada(e); crio uma nova entrada 
       
            try {
                if (de.EntradaDeProduto() == true) { // aki eu salvo a entrada no banco
                JOptionPane.showMessageDialog(rootPane, "CADASTRO REALIZADO COM SUCESSO !");
            }else{
                JOptionPane.showMessageDialog(rootPane, "ERRO AO REALIZAR CADASTRO !");
            }
        } catch (ClassNotFoundException ex) {
            Logger.getLogger(Entrada.class.getName()).log(Level.SEVERE, null, ex);
        }
       }else{
           JOptionPane.showMessageDialog(rootPane, "ERRO NO UPDATE !");
       }

Meus metodos:

public Produto MontarProduto(String nome){
        String SQL = "select nome,qtd from produto where nome like '"+nome+"'";
        Produto p = new Produto();
        try {
            PreparedStatement ps = con.prepareStatement(SQL);
            ResultSet rs = ps.executeQuery();

            while(rs.next()){ //enqnt houver linhas execute abaixo:
               // cria um produto
              p.setNome(rs.getString("nome")); // coloca o nome do banco nesse produto
              p.setQtd(rs.getInt("qtd")); // coloca a qtd do banco nesse produto
           }
           return p; //retorno a lista para usar na tela



        } catch (SQLException e) {
            // se houve algum erro, uma exceção é gerada para informar o erro
            e.printStackTrace(); //vejamos que erro foi gerado e quem o gerou
            return p;
        } finally {


            /*try {
                con.close();
            } catch (SQLException onConClose) {
                //System.out.println("Houve erro no fechamento da conexão");
                onConClose.printStackTrace();
            }*/
        } // fim do bloco try-catch-finally
    }
public boolean EntradaDeProduto() throws ClassNotFoundException {
        
        boolean retorno = false;

        String SQL = "insert into entrada values(?,?,?,?)";

        try {
            
            PreparedStatement ps = con.prepareStatement(SQL);
            //gravando a entrada no banco
            ps.setString(1, getEntrada().getData());
            ps.setString(2, getEntrada().getProduto().getNome());
            ps.setInt(3, getEntrada().getProduto().getQtd());
            ps.setInt(4, getEntrada().getQtd());
            ps.execute();
                //ps.clearParameters();
            
                //Recadastrando o produto com a nova qtd
            retorno = true;
        } catch (SQLException e) {
            // se houve algum erro, uma exceção é gerada para informar o erro
            e.printStackTrace(); //vejamos que erro foi gerado e quem o gerou
            retorno = false;
            // return false;
        } finally {


            /*try {
                con.close();
            } catch (SQLException onConClose) {
                //System.out.println("Houve erro no fechamento da conexão");
                onConClose.printStackTrace();
                return retorno;
            }*/
        } // fim do bloco try-catch-finally
        
        return retorno;
    }

Porque tah dando akele erro?

Qual das linhas é a 70? Talvez ‘con’ seja null.

va viu se algum dos valores passados é null?

  ps.setString(1, getEntrada().getData());  
  ps.setString(2, getEntrada().getProduto().getNome());  
  ps.setInt(3, getEntrada().getProduto().getQtd());  
  ps.setInt(4, getEntrada().getQtd());  

A linha 70 eh essa:

PreparedStatement ps = con.prepareStatement(SQL);

Onde vc iniciou con?