zoukankan      html  css  js  c++  java
  • 关于JPasswordField的getText()方法过时问题解决

      这几天想做一个登陆界面,用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(),比较的是字符串是否一样。

  • 相关阅读:
    Linux下校验下载文件的完整性(MD5,SHA1,PGP)
    十六进制字节 & 十六进制转二进制
    session & cookie
    php与mysql的链接到底用mysql 还是mysqli,pdo
    php连接数据库时候的字符集设置
    Prepared statements(mysqli & pdo)
    shell脚本中执行mysql命令
    centos系统字符编码问题
    实用crontab命令
    shell获取用户输入
  • 原文地址:https://www.cnblogs.com/lzy321/p/9975053.html
Copyright © 2011-2022 走看看