JSF динамическая навигация вообще не работает - PullRequest
0 голосов
/ 30 октября 2011

У меня есть 3 страницы jsf, сначала для вставки данных, имени пользователя и пароля, затем посмотрите, существуют ли данные в базе данных, после этого навигация сыграет роль перенаправления либо на страницу приветствия в случае успеха, либо на неверную страницу, если данные не существуют, вот код:

Код ManagedBean:

    private String userName;
    private String password;
    setters() & getters() 
    DBManager m = new DBManager(); 

  public String checkStatus() throws Exception{
    ResultSet rs = m.ExecuteQuery("select count(*) from user_authentication where user_name = 
   '"+userName+"' and user_password ='"+password+"' ");

   if(rs.next())  
    return "loggedIn";
         return "loggedOut";
}

DBManager.java код:

 public  Connection getConnection() {
    Connection cn = null;
    try{
        Class.forName("com.mysql.jdbc.Driver");  
        cn = DriverManager.getConnection("jdbc:mysql://localhost/recruitment","root","123");
    }catch(Exception e){
    }        
    return cn;
  }


  public ResultSet ExecuteQuery(String sql)  {
    ResultSet rs = null;
    Statement st = null;
    try {
        st = getConnection().createStatement();
        rs   = st.executeQuery(sql); 

    } catch (SQLException ex) {
        Logger.getLogger(DBManager.class.getName()).log(Level.SEVERE, null, ex);
    }
    return rs;
 }

код лица лиц:

<?xml version='1.0' encoding='UTF-8'?>
<faces-config version="2.0"
xmlns="http://java.sun.com/xml/ns/javaee" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee  

/web-facesconfig_2_0.xsd">
<managed-bean>
<managed-bean-name>obj</managed-bean-name>
<managed-bean-class>model.login</managed-bean-class>
<managed-bean-scope>session</managed-bean-scope>
</managed-bean>

<navigation-rule>
<from-view-id>/login.xhtml</from-view-id>
<navigation-case>
<display-name>welcome.xhtml</display-name>
<from-action>#{obj.checkStatus}</from-action>
<from-outcome>loggedIn</from-outcome>
<to-view-id>/welcome.xhtml</to-view-id>
</navigation-case>
<navigation-case>
<display-name>wrong.xhtml</display-name> 
<from-action>#{obj.checkStatus}</from-action>
<from-outcome>loggedOut</from-outcome>
<to-view-id>/wrong.xhtml</to-view-id>    
</navigation-case>
</navigation-rule>
</faces-config>

вот код страницы входа в систему JSF:

<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 <html xmlns="http://www.w3.org/1999/xhtml"
  xmlns:h="http://java.sun.com/jsf/html"
  xmlns:f="http://java.sun.com/jsf/core">
 <h:head>
    <title>Facelet Title</title>
 </h:head>
 <h:body>
    Hello from Facelets
    <f:view>
    <h:form>
        user name   <h:inputText value="#{obj.userName}"/>
        password  <h:inputSecret value="#{obj.password}"/>
        <h:commandButton value="log-in" type="submit" action="#{obj.checkStatus()}"/>
    </h:form>
        </f:view>
</h:body>
</html>

Другие 2 страницы jsf сообщают, успешно ли выполнена операция. Проблема в том, что страница входа перенаправляется на страницу приветствия независимо от правильности вставляемых данных.

Ответы [ 2 ]

1 голос
/ 30 октября 2011

A SELECT count(*) будет всегда возвращать результат. Подсчет 0 также является действительным результатом. Другими словами, ваш rs.next() всегда возвращает true. Чтобы решить вашу проблему, вы должны выбрать какой-то столбец вместо count(*).

Смотри также:


Не имеет отношения к конкретной проблеме , у вас огромная дыра SQL-инъекция , и код утечки ресурсов БД. Никогда не объединяйте пользовательские переменные в строку SQL, а вместо этого используйте PreparedStatement. Также всегда закрывайте ресурсы БД, такие как Connection, Statement и ResultSet в блоке finally try, в котором они были открыты.

Смотри также:

0 голосов
/ 30 октября 2011

Во-первых, если вы действительно используете JSF2, то все эти записи (относительно управляемого бина и правила навигации) в faces-config.xml не требуются.

Чтобы перенаправить, добавьте «?face-redirect = true» к возвращаемому значению метода действия:

return "loggedIn?faces-redirect=true";
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...