日期:2014-05-20  浏览次数:20800 次

JSF 中使用PreparedStatement的setString问题
下面用户登陆验证代码运行后,把正确的用户名和密码输入后,与数据库存放的用户名和密码核对总是不成功,请老师知道一下:

14.   public   class   UserBean   {

15.         private   String   name;

16.         private   String   password;

17.         private   boolean   loggedIn;

18.         private   Logger   logger   =   Logger.getLogger( "com.corejsf ");

19.
              public   void   doLogin()   throws   SQLException,   NamingException   {

50.               Context   ctx   =   new   InitialContext();

51.               if   (ctx   ==   null)   throw   new   NamingException( "No   initial   context ");


53.               DataSource   ds   =   (DataSource)   ctx.lookup                               ( "java:comp/env/jdbc/mydb ");

54.               if   (ds   ==   null)   throw   new   NamingException( "No   data   source ");


56.               Connection   conn   =   ds.getConnection();

57.               if   (conn   ==   null)   throw   new   SQLException( "No   connection ");


59.               try   {

60.                     PreparedStatement   passwordQuery   =   conn.prepareStatement(

61.                           "SELECT   password   from   Users   WHERE   username   =   ? ");


63.                     passwordQuery.setString(1,   name);


65.                     ResultSet   result   =   passwordQuery.executeQuery();


67.                     if   (!result.next())   return;

68.                     String   storedPassword   =   result.getString( "password ");

69.                     loggedIn   =   password.equals(storedPassword.trim());

70.               }

71.               finally   {

72.                     conn.close();

73.               }

74.         }

75.   }


但将 "SELECT   password   from   Users   WHERE   username   =   ? "     改为 "SELECT   password   from   Users   WHERE   username   =   'name ' ",并且去掉   passwordQuery.setString(1,   name);这行后,就可以和数据库存放的用户名和密码核对成功。     这是为什么?谢谢大家!