这几天想做一个登陆界面,用J 做,连接数据库时发现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方法是 的方法,返回的是HashCode
改成
-
if( String.valueOf( regi.getPassword()).equals(rs.getString(3))){
.................
}
就完全正确了,成功取出了密码的字符串。
还有就是不能用==,这样比较的是内存位置是否一样。
用.equals(),比较的是字符串是否一样。
继续阅读与本文标签相同的文章
下一篇 :
Java阐述方法输入参数的几种用法及实例剖析
-
菜鸟如何在阿里云快速建站(pc站+手机站+公众号+小程序)
2026-05-19栏目: 教程
-
ansible--copy与fetch模块
2026-05-19栏目: 教程
-
Elasticsearch Bucket聚合(桶聚合) 第一篇(常用桶聚合一览)
2026-05-19栏目: 教程
-
ansible安装
2026-05-19栏目: 教程
-
ansible--user和group模块用户创建及删除
2026-05-19栏目: 教程
