2013-07-03 2 views
0

이전에 문제를 물었지만 명확하지 않았습니다. 그래서 나는 저를 이해하기를 희망하면서 다시 질문을합니다. 내 응용 프로그램에 대한 사용자 세션을 만들고 싶습니다. 따라서 사용자는 내 홈페이지에 액세스하려면 로그인해야합니다. 이를 위해 Bean과 필터를 만듭니다. 내가 할 수있게이 질문에 대한 대답을 JSF HTTP Session Login으로 사용했습니다. 그러나 필터의 userManager은 항상 null입니다. 나는이 줄에 연결된 사용자의 가치를 어떻게 넣을 지 모른다.JSF 2.0 사용자 세션

UserManager userManager = (UserManager) req.getSession().getAttribute("userManager"); 

다음은 필터입니다.

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { 

HttpServletRequest req = (HttpServletRequest) request; 
HttpServletResponse res = (HttpServletResponse) response; 
UserManager userManager = (UserManager) req.getSession().getAttribute("userManager");  
String loginURL = req.getContextPath() + "/index.jsf"; 

if (userManager == null && !userManager.isLoggedIn() && !req.getRequestURI().equals(loginURL)) { 

    res.sendRedirect(loginURL); 

} else { 

    res.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1. 
    res.setHeader("Pragma", "no-cache"); // HTTP 1.0. 
    res.setDateHeader("Expires", 0); // Proxies. 

    chain.doFilter(request, response); 

} 

나는 경우 !userManager.isLoggedIn()에서이 조건을 넣을 때, 나는 말한다 마커가 있습니다

널 포인터 액세스 : 변수 userManager은이 위치에 null이 될 수 있으며, 1 빠른 수정 가능한 추가하기 @SuppressWarnings 'null'to 'doFilter()'

나는 그것을 추가하려고 시도했지만 실행했습니다. 오류 java.lang.NullPointerException이 있습니다. JSF에서 초보자입니다. 제발, 네 도움이 필요해.

ERROR [org.apache.catalina.core.ContainerBase.[jboss.web].[localhost].[/jsf-formulaire].[Faces Servlet]] "Servlet.service()" pour la servlet Faces Servlet a généré une exception: java.lang.NullPointerException 
at com.citech.pointage.fe.bean.filters.SessionFilter.doFilter(SessionFilter.java:61) [:] 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:274) [:6.1.0.Final] 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:242) [:6.1.0.Final] 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:275) [:6.1.0.Final] 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:161) [:6.1.0.Final] 
at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:181) [:6.1.0.Final] 
at org.jboss.modcluster.catalina.CatalinaContext$RequestListenerValve.event(CatalinaContext.java:285) [:1.1.0.Final] 
at org.jboss.modcluster.catalina.CatalinaContext$RequestListenerValve.invoke(CatalinaContext.java:261) [:1.1.0.Final] 
at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:88) [:6.1.0.Final] 
at org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.invoke(SecurityContextEstablishmentValve.java:100) [:6.1.0.Final] 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:159) [:6.1.0.Final] 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) [:6.1.0.Final] 
at org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:158) [:6.1.0.Final] 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) [:6.1.0.Final] 
at org.jboss.web.tomcat.service.request.ActiveRequestResponseCacheValve.invoke(ActiveRequestResponseCacheValve.java:53) [:6.1.0.Final] 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:362) [:6.1.0.Final] 
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:877) [:6.1.0.Final] 
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:654) [:6.1.0.Final] 
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:951) [:6.1.0.Final] 
at java.lang.Thread.run(Unknown Source) [:1.6.0_03] 
+0

이것은 JSF 문제가되지 않습니다. 이것은 단지 기본 Java입니다. 부울 논리를 배우는 데 더 많은 시간을 투자하십시오. – BalusC

답변

0

귀하의 조건은 다음과 같아야합니다

if ((userManager == null || !userManager.isLoggedIn()) && 
    !req.getRequestURI().equals(loginURL)) // first && replaced by || 

이제 JSF HTTP Session Login 작업을 계속할 수 있습니다.

<f:metadata> 
    <f:event type="preRenderView" listener="#{securityMB.checkLogIn}" /> 
</f:metadata> 

을 그리고 당신의 관리 빈 : 사용자를 확인하는 또 다른 옵션은 JSF 메타 데이터에서 PreRenderView 이벤트와, 그냥 페이지에이 추가

@ManagedBean(name = "securityMB") 
@RequestScoped 
public class SecurityBean { 
    @ManagedProperty(value = "#{userManager}") 
    private UserManager userManager; 
    String loginURL = "/index.jsf"; 
    public void checkLogIn() { 
    if (userManager == null || !userManager.isLoggedIn()) { 
    FacesContext.getCurrentInstance().getExternalContext().redirect(loginURL); 
    } 
    //getter and setter (userManager) 
} 
+0

@ danRod : 답변 해 주셔서 감사합니다. 나는 아주 행복하다. 나는 당신이 나를 보여준 것처럼 나의 상태를 바꾸었고 더 이상이 마커가 없습니다. 그러나 세션은 아직 만들어지지 않습니다. 사실, 자격 증명을 입력하고 양식의 유효성을 검사하면 홈페이지로 리디렉션됩니다. 그러나 로그 아웃을 클릭해도 아무런 변화가 없습니다. 그래서 나는'System.out.println ("not connected");을'if'와'System.out.println ("connected");'else'에 놓았고 응용 프로그램을 다시 실행합니다. 로그 아웃을 클릭하면 콘솔에서이 추적을 볼 수 있습니다 :'System.out.println ("not connected");'. 도와 줄수있으세요? – Princesse

+0

'userManager'가 null이라고 생각합니다. 그래서이 조건 :'if ((userManager == null ||! userManager.isLoggedIn()) && ! req.getRequestURI(). equals (loginURL))'은 항상 검증됩니다. 어떻게해야합니까? – Princesse

+0

@Princesse는 귀하의 조건에서'req.getRequestURI(). equals (loginURL)'을 삭제하고 시도하십시오. 세션 빈을 붙여 주실 수 있습니까? – danRod