这几天想做一个登陆界面,用Jframe做,连接数据库时发现JPasswordField的getText()过时了,没法使用。查了资料发现改成了:
try{
String sql="SELECT * FROM username WHERE name=?";
conn = DB.getConnection();
prst = conn.prepareStatement(sql);
String lll= Login.getText();
System.out.println(lll);
prst.setString(1,lll);
prst.execute();
rs = prst.executeQuery();
if (rs.next()){
if( String.valueOf( regi.getPassword()).equals(rs.getString(3))){
JOptionPane.showMessageDialog(Main, "成功", "错误",JOptionPane.WARNING_MESSAGE);
}else {
System.out.println(rs.getString(3));
System.out.println(regi.getPassword().toString());
JOptionPane.showMessageDialog(Main, "账户密码错误", "错误",JOptionPane.WARNING_MESSAGE);
}
}else{
JOptionPane.showMessageDialog(Main, "无此用户", "错误",JOptionPane.WARNING_MESSAGE);
}
}catch (Exception e1){
e1.printStackTrace();
} finally {
DB.close(rs);
DB.close(prst);
DB.close(conn);
}
}
- if(regi.getPassword.toString.equals(rs.getString(3)))){
.............//数据库里面列是从1开始的所以密码是三列
}
会出现以下错误:
第二个是System.out.println(regi.getPassword.toString);
查资料发现这个toString方法是object的方法,返回的是HashCode
改成
-
if( String.valueOf( regi.getPassword()).equals(rs.getString(3))){
.................
}
就完全正确了,成功取出了密码的字符串。
还有就是不能用==,这样比较的是内存位置是否一样。
用.equals(),比较的是字符串是否一样。