2012-02-22 62 views
0

我有一個PhaseListener,不起作用。但在我的同事的電腦中,如果它工作的話。我phaseListener不工作

我使用NetBeans 6.8在GlassFish 2.1和Windows 32位

的PhaseListener在:

package mx.udg.cgti.seguridad.listener; 

import java.util.Enumeration; 
import java.util.logging.Level; 
import java.util.logging.Logger; 
import javax.faces.application.NavigationHandler; 
import javax.faces.context.FacesContext; 
import javax.faces.event.PhaseListener; 
import javax.faces.event.PhaseEvent; 
import javax.faces.event.PhaseId; 
import javax.naming.Context; 
import javax.naming.InitialContext; 
import javax.naming.NamingException; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpSession; 
import mx.udg.cgti.seguridadcore.negocio.ProcesosCNLocal; 

public class SeguridadCorePhaseListener implements PhaseListener { 

    public SeguridadCorePhaseListener() { 
    } 

    public void beforePhase(PhaseEvent pe) { 
     System.out.println("beforePhase"); 
    } 

    public void afterPhase(PhaseEvent pe) { 
     System.out.println("afterPhase"); 
     if (pe.getPhaseId().equals(PhaseId.RESTORE_VIEW)) { 

      if (pe.getFacesContext() != null) { 

       String pagina = pe.getFacesContext().getViewRoot().getViewId(); 
       if (!"/Inicio.xhtml".equalsIgnoreCase(pagina) && !"/Login.xhtml".equalsIgnoreCase(pagina) && pagina.contains(".xhtml")) { 
        loggedIn(); 
       } 
      } 
     } 
    } 

    private void loggedIn() { 
     String pagina = ""; 
     Long token = obtenToken(); 
     if (token != null) { 
      String result = ""; 
      result = lookupProcesosCNLocal().getSesionActiva(token); 
      if ("".equalsIgnoreCase(result)) { 
       result = null; 
      } 
//   System.out.println("RESULT " + result); 
      if (result == null) { 
       pagina = new String("sessionTimeout"); 
      } 
     } else { 
      pagina = new String("sinSession"); 
     } 
//  System.out.println(" PAGINA :- " + pagina + " TOKEN " + token); 
     if (!pagina.equalsIgnoreCase("")) { 
//   System.out.println("REGLAS DE NAVEGACION TRABAJANDO HACIA " + pagina); 
      FacesContext fc = FacesContext.getCurrentInstance(); 
      NavigationHandler nh = fc.getApplication().getNavigationHandler(); 
      nh.handleNavigation(fc, null, pagina); 
      fc.renderResponse(); 
     } 

    } 

    private Long obtenToken() { 
     Long token = null; 
     HttpServletRequest request = (HttpServletRequest) FacesContext.getCurrentInstance().getExternalContext().getRequest(); 
     HttpSession session = (HttpSession) FacesContext.getCurrentInstance().getExternalContext().getSession(false); 
     Object t = request.getAttribute("token"); 
     if (t == null) { 
      Object obj=null; 
      if(session != null){ 
       obj = session.getAttribute("token"); 
       if(obj == null){ 
        obj = request.getParameter("token"); 
       } 
      }else{ 
       obj = request.getParameter("token"); 
      } 
      if (obj != null) { 
       if (obj != null && !"".equalsIgnoreCase(obj.toString())) { 
        token = Long.parseLong(obj.toString()); 
       } 
      } 
     } else { 
      token = Long.parseLong(t.toString()); 
     } 
     if (token != null) { 
      request.setAttribute("token", token); 
      if(session == null){ 
       session = (HttpSession) FacesContext.getCurrentInstance().getExternalContext().getSession(true); 
      } 
      session.setAttribute("token", token); 
     } 
     return token; 
    } 

    public PhaseId getPhaseId() { 
     return PhaseId.RESTORE_VIEW; 
    } 

    private ProcesosCNLocal lookupProcesosCNLocal() { 
     try { 
      Context c = new InitialContext(); 
      return (ProcesosCNLocal) c.lookup("java:comp/env/ProcesosCN"); 
     } catch (NamingException ne) { 
      Logger.getLogger(getClass().getName()).log(Level.SEVERE, "exception caught", ne); 
      throw new RuntimeException(ne); 
     } 
    } 

} 

faces-config.xml中

<?xml version='1.0' encoding='UTF-8'?> 

<!-- =========== FULL CONFIGURATION FILE ================================== --> 

<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"> 

    <navigation-rule> 
     <from-view-id>/*</from-view-id> 
     <navigation-case> 
      <from-outcome>logear</from-outcome> 
      <to-view-id>/Login.xhtml</to-view-id> 
      <redirect>1</redirect> 
     </navigation-case> 
     <navigation-case> 
      <from-outcome>sessionTimeout</from-outcome> 
      <to-view-id>/LoginError.xhtml</to-view-id> 
     </navigation-case> 
     <navigation-case> 
      <from-outcome>sinSession</from-outcome> 
      <to-view-id>/LoginError.xhtml</to-view-id> 
     </navigation-case> 
    </navigation-rule>  
    <application> 
     <message-bundle> 
      mx.udg.cgti.seguridad.boundle.MiBoundle 
     </message-bundle> 
    </application> 
    <lifecycle> 
     <phase-listener>mx.udg.cgti.seguridad.listener.SeguridadCorePhaseListener</phase-listener> 
    </lifecycle> 
    <validator> 
     <validator-id>validaComboRequerido</validator-id> 
     <validator-class>mx.udg.cgti.seguridad.validator.ValidaComboRequerido</validator-class> 
    </validator> 
    <converter> 
     <converter-id>tipoUsuario</converter-id> 
     <converter-class>mx.udg.cgti.ln.convertidor.TipoUsuarioConverter</converter-class> 
    </converter> 
    <converter> 
     <converter-id>Usuario</converter-id> 
     <converter-class>mx.udg.cgti.ln.convertidor.UsuarioConverter</converter-class> 
    </converter> 
    <converter> 
     <converter-id>Rol</converter-id> 
     <converter-class>mx.udg.cgti.ln.convertidor.RolConverter</converter-class> 
    </converter> 
    <converter> 
     <converter-id>Permiso</converter-id> 
     <converter-class>mx.udg.cgti.ln.convertidor.PermisoConverter</converter-class> 
    </converter> 
    <converter> 
     <converter-id>UnidadOrganizacional</converter-id> 
     <converter-class>mx.udg.cgti.ln.convertidor.UnidadOrganizacionalConverter</converter-class> 
    </converter> 

</faces-config> 
+0

請詳細說明「不起作用」。有什麼症狀?你在服務器日誌中看到什麼? – BalusC 2012-02-22 20:20:41

+0

好的。從理論上說,聽衆必須允許或拒絕對用戶的訪問。 監聽器只是讓所有用戶都有權限,我們試圖在方法'beforePhase'和'afterPhase'中放入'System.out.println'函數來查看是否打印在控制檯上。但我的電腦沒有顯示信息。 – appmaster 2012-02-28 18:33:27

回答

0

顯然,你已經中完全另一個版本類路徑中的某個類在類加載中的優先級高於WAR中包含的類。

它可以位於服務器本身的/lib文件夾內,也可以位於服務器使用的已安裝JRE的/lib/lib/ext文件夾內。

+0

謝謝。我在我的項目的屬性中更改了jar文件的順序,現在可以正常工作。 – appmaster 2012-02-28 20:24:35

+0

不客氣。 – BalusC 2012-02-28 20:28:34