I'm using JDBC to connect my program to a MySQL database.
I already put the port number and yes, my database have permission to access.
When i use localhost work perfectly, but when i try connect to a remote MySQL database, show this error on console.
java.lang.ExceptionInInitializerError
Caused by: java.lang.NumberFormatException: null
at java.lang.Integer.parseInt(Integer.java:454)
at java.lang.Integer.parseInt(Integer.java:527)
at serial.BDArduino.<clinit>(BDArduino.java:25)
Exception in thread "main" Java Result: 1
CONSTRUÍDO COM SUCESSO (tempo total: 1 segundo)
Thank you in Advance !
MAIN CODE
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package serial;
import gnu.io.CommPort;
import gnu.io.CommPortIdentifier;
import gnu.io.SerialPort;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import javax.swing.JFrame;
import javax.swing.JOptionPane;
/**
*
* @author Ruiz
*/
public class BDArduino extends JFrame {
static boolean connected = false;
static int aux_sql8 = Integer.parseInt(Sql.getDBinfo("SELECT * FROM arduinoData WHERE id=1", "pin8"));
static int aux_sql2 = Integer.parseInt(Sql.getDBinfo("SELECT * FROM arduinoData WHERE id=1", "pin2"));
CommPort commPort = null;
SerialPort serialPort = null;
InputStream inputStream = null;
static OutputStream outputStream = null;
String comPortNum = "COM10";
int baudRate = 9600;
int[] intArray = {2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13};
/**
* Creates new form ArduinoTest
*/
public BDArduino() {
//super("Arduino Test App");
initComponents();
}
class Escrita extends Thread {
private int i;
public void run() {
while (true) {
System.out.println("Número :" + i++);
}
}
}
//public void actionPerformed(ActionEvent e) {
// String arg = e.getActionCommand();
public static void writeData(int a) throws IOException {
outputStream.write(a);
}
public void action(String arg) {
System.out.println(arg);
Object[] msg = {"Baud Rate: ", "9600", "COM Port #: ", "COM10"};
if (arg == "connect") {
if (connected == false) {
new BDArduino.ConnectionMaker().start();
} else {
closeConnection();
}
}
if (arg == "disconnect") {
serialPort.close();
closeConnection();
}
if (arg == "p2") {
System.out.print("Pin #2\n");
try {
outputStream.write(intArray[0]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p3") {
System.out.print("Pin #3\n");
try {
outputStream.write(intArray[1]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p4") {
System.out.print("Pin #4\n");
try {
outputStream.write(intArray[2]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p5") {
System.out.print("Pin #5\n");
try {
outputStream.write(intArray[3]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p6") {
System.out.print("Pin #6\n");
try {
outputStream.write(intArray[4]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p7") {
System.out.print("Pin #7\n");
try {
outputStream.write(intArray[5]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p8") {
System.out.print("Pin #8\n");
try {
outputStream.write(intArray[6]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p9") {
System.out.print("Pin #9\n");
try {
outputStream.write(intArray[7]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p10") {
System.out.print("Pin #10\n");
try {
outputStream.write(intArray[8]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p11") {
System.out.print("Pin #11\n");
try {
outputStream.write(intArray[9]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p12") {
System.out.print("Pin #12\n");
try {
outputStream.write(intArray[10]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
if (arg == "p13") {
System.out.print("Pin #12\n");
try {
outputStream.write(intArray[11]);
}//end try
catch (IOException e12) {
e12.printStackTrace();
System.exit(-1);
}//end catch
}
}
//*******************************************************
//Arduino Connection ***************************************
//******************************************************
void closeConnection() {
try {
outputStream.close();
} catch (Exception ex) {
ex.printStackTrace();
String cantCloseConnectionMessage = "Can't Close Connection!";
JOptionPane.showMessageDialog(null, cantCloseConnectionMessage, "ERROR", JOptionPane.ERROR_MESSAGE);
}
connected = false;
System.out.print("\nDesconectado\n");
String disconnectedConnectionMessage = "Desconectado!";
JOptionPane.showMessageDialog(null, disconnectedConnectionMessage, "Desconectado", JOptionPane.INFORMATION_MESSAGE);
}//end closeConnection()
void connect() throws Exception {
String portName = comPortNum;
CommPortIdentifier portIdentifier = CommPortIdentifier.getPortIdentifier(portName);
if (portIdentifier.isCurrentlyOwned()) {
System.out.println("Error: Port is currently in use");
String portInUseConnectionMessage = "Port is currently in use!\nTry Again Later...";
JOptionPane.showMessageDialog(null, portInUseConnectionMessage, "ERROR", JOptionPane.ERROR_MESSAGE);
} else {
commPort = portIdentifier.open(this.getClass().getName(), 2000);
if (commPort instanceof SerialPort) {
serialPort = (SerialPort) commPort;
serialPort.setSerialPortParams(baudRate, SerialPort.DATABITS_8, SerialPort.STOPBITS_1, SerialPort.PARITY_NONE);
outputStream = serialPort.getOutputStream();
} else {
System.out.println("Error: Only serial ports are handled ");
String onlySerialConnectionMessage = "Serial Ports ONLY!";
JOptionPane.showMessageDialog(null, onlySerialConnectionMessage, "ERROR", JOptionPane.ERROR_MESSAGE);
}
}//end else
//wait some time
try {
Thread.sleep(300);
} catch (InterruptedException ie) {
}
}//end connect
//*******************************************************
//*innerclasses******************************************
//*******************************************************
public class ConnectionMaker extends Thread {
public void run() {
//try to make a connection
try {
connect();
} catch (Exception ex) {
ex.printStackTrace();
System.out.print("ERROR: Cannot connect!");
String cantConnectConnectionMessage = "Cannot Connect!\nCheck the connection settings\nand/or your configuration\nand try again!";
JOptionPane.showMessageDialog(null, cantConnectConnectionMessage, "ERROR", JOptionPane.ERROR_MESSAGE);
}
//show status
serialPort.notifyOnDataAvailable(true);
connected = true;
//send ack
System.out.print("\nConnected\n");
String connectedConnectionMessage = "Conectado!";
JOptionPane.showMessageDialog(null, connectedConnectionMessage, "Conectado", JOptionPane.INFORMATION_MESSAGE);
}//end run
}//end ConnectionMaker
/**
* This method is called from within the constructor to initialize the form.
* WARNING: Do NOT modify this code. The content of this method is always
* regenerated by the Form Editor.
*/
@SuppressWarnings("unchecked")
// <editor-fold defaultstate="collapsed" desc="Generated Code">
private void initComponents() {
btnp2 = new javax.swing.JButton();
btncon = new javax.swing.JButton();
btndesc = new javax.swing.JButton();
btnp3 = new javax.swing.JButton();
btnp4 = new javax.swing.JButton();
btnp5 = new javax.swing.JButton();
btnp9 = new javax.swing.JButton();
btnp6 = new javax.swing.JButton();
btnp7 = new javax.swing.JButton();
btnp8 = new javax.swing.JButton();
btn13 = new javax.swing.JButton();
btnp10 = new javax.swing.JButton();
btnp11 = new javax.swing.JButton();
btnp12 = new javax.swing.JButton();
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
btnp2.setText("2");
btnp2.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp2MouseClicked(evt);
}
});
btncon.setText("Conectar");
btncon.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnconMouseClicked(evt);
}
});
btndesc.setText("Desconectar");
btndesc.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btndescMouseClicked(evt);
}
});
btnp3.setText("3");
btnp3.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp3MouseClicked(evt);
}
});
btnp4.setText("4");
btnp4.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp4MouseClicked(evt);
}
});
btnp5.setText("5");
btnp5.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp5MouseClicked(evt);
}
});
btnp9.setText("9");
btnp9.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp9MouseClicked(evt);
}
});
btnp6.setText("6");
btnp6.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp6MouseClicked(evt);
}
});
btnp7.setText("7");
btnp7.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp7MouseClicked(evt);
}
});
btnp8.setText("8");
btnp8.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp8MouseClicked(evt);
}
});
btn13.setText("13");
btn13.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btn13MouseClicked(evt);
}
});
btnp10.setText("10");
btnp10.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp10MouseClicked(evt);
}
});
btnp11.setText("11");
btnp11.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp11MouseClicked(evt);
}
});
btnp12.setText("12");
btnp12.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent evt) {
btnp12MouseClicked(evt);
}
});
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
getContentPane().setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGap(20, 20, 20)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
.addGroup(layout.createSequentialGroup()
.addComponent(btncon)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
.addComponent(btndesc))
.addGroup(layout.createSequentialGroup()
.addComponent(btnp6, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp7, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp8, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp9, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE))
.addGroup(layout.createSequentialGroup()
.addComponent(btnp10, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp11, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp12, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btn13, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE))
.addGroup(layout.createSequentialGroup()
.addComponent(btnp2, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp3, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp4, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(btnp5, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE)))
.addContainerGap(20, Short.MAX_VALUE))
);
layout.setVerticalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addContainerGap()
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(btncon)
.addComponent(btndesc))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, 20, Short.MAX_VALUE)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(btnp2)
.addComponent(btnp3)
.addComponent(btnp4)
.addComponent(btnp5))
.addGap(18, 18, 18)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(btnp6)
.addComponent(btnp7)
.addComponent(btnp8)
.addComponent(btnp9))
.addGap(18, 18, 18)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(btnp10)
.addComponent(btnp11)
.addComponent(btnp12)
.addComponent(btn13))
.addGap(22, 22, 22))
);
pack();
}// </editor-fold>
private void btnp2MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p2");
}
private void btnconMouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("connect");
}
private void btndescMouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("disconnect");
}
private void btnp3MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p3");
}
private void btnp4MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p4");
}
private void btnp5MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here
action("p5");
}
private void btnp9MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p9");
}
private void btnp6MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p6");
}
private void btnp7MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p7");
}
private void btnp8MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p8");
}
private void btn13MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p13");
}
private void btnp10MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p10");
}
private void btnp11MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p11");
}
private void btnp12MouseClicked(java.awt.event.MouseEvent evt) {
// TODO add your handling code here:
action("p12");
}
/**
* @param args the command line arguments
*/
public static void main(String args[]) throws IOException {
/* Set the Nimbus look and feel */
//<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
/* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel.
* For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html
*/
try {
for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
if ("Nimbus".equals(info.getName())) {
javax.swing.UIManager.setLookAndFeel(info.getClassName());
break;
}
}
} catch (Exception e) {
}
//</editor-fold>
/* Create and display the form */
java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
new BDArduino().setVisible(true);
}
});
//}
while (true) {
//
int sql8 = Integer.parseInt(Sql.getDBinfo("SELECT * FROM arduinoData WHERE id=1", "pin8"));
if (connected == true && sql8 != aux_sql8) {
aux_sql8 = sql8;
if(sql8 == 1){
writeData(2);
}else{
writeData(3);
}
}
int sql2 = Integer.parseInt(Sql.getDBinfo("SELECT * FROM arduinoData WHERE id=1", "pin2"));
if (connected == true && sql2 != aux_sql2) {
aux_sql2 = sql2;
if(sql2 == 1){
writeData(4);
}else{
writeData(5);
}
}
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
// Variables declaration - do not modify
private javax.swing.JButton btn13;
private javax.swing.JButton btncon;
private javax.swing.JButton btndesc;
private javax.swing.JButton btnp10;
private javax.swing.JButton btnp11;
private javax.swing.JButton btnp12;
private javax.swing.JButton btnp2;
private javax.swing.JButton btnp3;
private javax.swing.JButton btnp4;
private javax.swing.JButton btnp5;
private javax.swing.JButton btnp6;
private javax.swing.JButton btnp7;
private javax.swing.JButton btnp8;
private javax.swing.JButton btnp9;
// End of variables declaration
}