Hola muy buenas tengo un problema con el código, no puedo acceder a la siguiente ventana , no me entra el usuario y contraseña.
Tengo creado un puente con JDBC y un MySQL con una base de datos llamada practica, para los usuarios lo que tengo echo es una tabla con los campos idUsuario, usuario,password.
Lo que me gustaría es entrar al siguiente Framer dependiendo del usuario que sea, por ejemplo:
Si inicio sesión con el usuario: administrador que se me abra un Framer o si inicio sesión con otro usuario distinto que se abra otro framer diferente.
Código:
package VentanaLogin;
import javax.swing.*;
import java.io.*;
import java.sql.*;
import java.awt.Panel.*;
import java.awt.*;
import java.awt.event.*;
public class VentanaLogin extends JFrame
{
private JTextField txtUser, txtPass;
private JLabel lblUser, lblPass;
private JButton btnAceptar, btnCancelar;
String usuario, elPassword;
//Crear un objeto tipo Connection
Connection unaConexion=null;
String dsn=new String("jdbc:odbc:puentejava");
VentanaLogin()
{
Container contenedor = getContentPane();
contenedor.setLayout(new FlowLayout());
// crear etiqueta y cuadro de texxto del usuario
txtUser = new JTextField(10);
lblUser = new JLabel("Usuario: ");
txtUser.setToolTipText("Escriba su nombre de usuario");
contenedor.add( Box.createVerticalStrut(50) );
contenedor.add(lblUser);
contenedor.add(txtUser);
//crear etiqueta y cuadro de texxto del pw
txtPass = new JPasswordField(10);
lblPass = new JLabel("Contraseña: ");
txtPass.setToolTipText("Escriba su contraseña");
contenedor.add(lblPass);
contenedor.add(txtPass);
//Crear y agregar los botones
btnAceptar = new JButton("Aceptar");
//establecer Boton aceptar por defecto
getRootPane().setDefaultButton(btnAceptar);
btnCancelar = new JButton("Cancelar");
contenedor.add(btnAceptar);
contenedor.add(btnCancelar);
// Crear un escuchador al boton Aceptar
ActionListener escuchadorbtnAceptar = new ActionListener()
{
public void actionPerformed(ActionEvent evt)
{
try
{
//chekar si el usuario escrbio el nombre de usuario y pw
if (txtUser.getText().length() > 0 && txtPass.getText().length() > 0 )
{
// Si el usuario si fue validado correctamente
if( validarUsuario( txtUser.getText(), txtPass.getText() ) ) //enviar datos a validar
{
// Codigo para mostrar la ventana principal
setVisible(false);
VentanaPrincipal ventana1 = new VentanaPrincipal();
ventana1.mostrar();
}
else
{
JOptionPane.showMessageDialog(null, "El nombre de usuario y/o contrasenia no son validos.");
JOptionPane.showMessageDialog(null, txtUser.getText()+" " +txtPass.getText() );
txtUser.setText(""); //limpiar campos
txtPass.setText("");
txtUser.requestFocusInWindow();
}
}
else
{
JOptionPane.showMessageDialog(null, "Debe escribir nombre de usuario y contrasenia.\n" +
"NO puede dejar ningun campo vacio");
}
} catch (Exception e)
{
e.printStackTrace();
}
}
};
btnAceptar.addActionListener(escuchadorbtnAceptar); // Asociar escuchador para el boton Aceptar
// Agregar escuchador al boton Cancelar
ActionListener escuchadorbtnCancelar=new ActionListener()
{
public void actionPerformed(ActionEvent evt)
{
System.exit(0); // terminar el programa
}
};
btnCancelar.addActionListener(escuchadorbtnCancelar); // Asociar escuchador para el boton Cancelar
setTitle("Autentificacion de usuarios");
setSize(400,150); // Tamaño del Frame
setResizable(false); // que no se le pueda cambiar el tamanio
//Centrar la ventana de autentificacion en la pantalla
Dimension tamFrame=this.getSize();//para obtener las dimensiones del frame
Dimension tamPantalla=Toolkit.getDefaultToolkit().getScreenSize(); //para obtener el tamanio de la pantalla
setLocation((tamPantalla.width-tamFrame.width)/2, (tamPantalla.height-tamFrame.height)/2); //para posicionar
setVisible(true); // Hacer visible al frame
} // fin de constructor
// Metodo que conecta con el servidor MYSQL y valida los usuarios
boolean validarUsuario(String elUsr, String elPw) throws IOException
{
try
{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
}
catch(ClassNotFoundException e)
{
System.out.println("Se ha producido un error al cargar el Driver");
}
try
{
unaConexion=DriverManager.getConnection(dsn,"root","studium");
}
catch(SQLException e)
{
System.out.println("Se produjo un error al conectar a la Base de Datos");
}
try
{
//nombre de la BD: bdlogin
//nombre de la tabla: usuarios
// id integer auto_increment not null <--llave primaria
// campos: usuario char(25)
// password char(50)
Connection unaConexion = DriverManager.getConnection ("jdbc:odbc:puentejava");
// Preparamos la consulta
Statement instruccionSQL = unaConexion.createStatement();
ResultSet resultadosConsulta = instruccionSQL.executeQuery ("SELECT usuario,password FROM usuarios WHERE usuario='"+elUsr+"' AND password='"+elPw+"'");
if( resultadosConsulta.first() ) // si es valido el primer reg. hay una fila, tons el usuario y su pw existen
return true; //usuario validado correctamente
else
return false; //usuario validado incorrectamente
} catch (Exception e)
{
e.printStackTrace();
return false;
}
}
public static void main(String[] args)
{
VentanaLogin prueba = new VentanaLogin();
prueba.setDefaultCloseOperation(prueba.EXIT_ON_CLOSE);
}
}
El otro framer que tengo creado es el siguiente:
Código:
package VentanaLogin;
import javax.swing.*;
import java.awt.*;
public class VentanaPrincipal extends JFrame
{
VentanaPrincipal()
{
setSize(400,400);
setTitle("ventana principal");
setLayout(new BorderLayout());
add(Box.createHorizontalStrut(100),BorderLayout.WEST);
add(new JLabel("Ventana principal del proyecto "),BorderLayout.CENTER);
setLocationRelativeTo(null);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
public void mostrar()
{
setVisible(true);
}
}