2012-01-27 7 views
2

해결책을 찾았지만 내 특정 문제에 대한 답을 찾을 수 없습니다. login.xhtml 페이지가 있지만 JSF 태그가 렌더링되지 않습니다. 성공적으로 로그인하면 태그가 올바르게 렌더링됩니다. 그래서 어떻게 든 login.xhtml은 faces 서블릿을 통과하지 못합니다. 모두 올바르게 구성 되었기 때문에 이상하게 보입니다. login.xhtml이 올바르게 렌더링되도록하려면 어떻게해야합니까?컨테이너 관리 로그인 페이지가 JSF 구성 요소를 렌더링하지 않습니다.

여기

<login-config> 
    <auth-method>FORM</auth-method> 
    <realm-name>file</realm-name> 
    <form-login-config> 
     <form-login-page>/login.xhtml</form-login-page> 
     <form-error-page>/error.xhtml</form-error-page> 
    </form-login-config> 
</login-config> 

<servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.jsf</url-pattern> 
</servlet-mapping> 

Login.xhtml

<ui:composition xmlns="http://www.w3.org/1999/xhtml" 
xmlns:ui="http://java.sun.com/jsf/facelets" 
xmlns:f="http://java.sun.com/jsf/core" 
xmlns:h="http://java.sun.com/jsf/html" 
xmlns:p="http://primefaces.org/ui" 
template="/WEB-INF/templates/eps_template.xhtml"> 
<ui:define name="body"> 

    <h2>Hello, please log in:</h2> 
    <form name="loginForm" method="post" action="j_security_check"> 
     <p> 
      <strong><label for="username">Please type your user 
        name: </label> </strong> <input id="username" type="text" name="j_username" 
       size="25" /> 
     </p> 
     <p> 
      <strong><label for="password">Please type your 
        password: </label> </strong> <input id="password" type="password" size="15" 
       name="j_password" /> 
     </p> 
     <p> 
      <input type="submit" value="Submit" /> <input type="reset" 
       value="Reset" /> 
     </p> 
    </form> 

</ui:define> 
</ui:composition> 

그래서 HTML 양식이 올바르게 표시됩니다 내 web.xml의 부분이지만, 템플릿 구성 요소는 아니다. 출력은 다음과 같습니다

<?xml version="1.0" encoding="UTF-8"?> 
<ui:composition xmlns="http://www.w3.org/1999/xhtml" 
xmlns:ui="http://java.sun.com/jsf/facelets" 
xmlns:f="http://java.sun.com/jsf/core" 
xmlns:h="http://java.sun.com/jsf/html" 
xmlns:p="http://primefaces.org/ui" 
template="/WEB-INF/templates/eps_template.xhtml"> 
<ui:define name="body"> 

    <h2>Hello, please log in:</h2> 
    <form name="loginForm" method="post" action="j_security_check"> 
     <p> 
      <strong><label for="username">Please type your user 
        name: </label> </strong> <input id="username" type="text" name="j_username" 
       size="25" /> 

     </p> 
     <p> 
      <strong><label for="password">Please type your 
        password: </label> </strong> <input id="password" type="password" size="15" 
       name="j_password" /> 
     </p> 
     <p> 
      <input type="submit" value="Submit" /> <input type="reset" 
       value="Reset" /> 
     </p> 

    </form> 

</ui:define> 
</ui:composition> 

업데이트 2012.01.31

구성 : 글래스 피시 3.1 Primefaces 3.1 JSF 2.1

내가 home.jsf에 전달하는 index.html 페이지가 있습니다. 그러나 컨테이너는 login.xhtml로 리디렉션되도록 사용자가 로그인하지 않았 음을 통지합니다.

* .jsf 만 web.xml에 추가하면 모두 정상적으로 작동하지만 login.jsf는 JSF 태그를 렌더링하지 않습니다.

<url-pattern>*.jsf</url-pattern> 
<url-pattern>*.xhtml</url-pattern> 

나는 또한 추가하는 경우 * login.jsf 페이지가 있지만 제대로 Primefaces 피부에 따르지 않는 태그를 렌더링하지 .xhtml. 제출을 클릭하면 jquery.js가 화면에 인쇄됩니다.

여기에 답이 후 BalusC에 의해

<servlet> 
    <servlet-name>Faces Servlet</servlet-name> 
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class> 
    <load-on-startup>1</load-on-startup> 
</servlet> 
<servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.jsf</url-pattern> 
    <url-pattern>*.xhtml</url-pattern> 
    <url-pattern>*.html</url-pattern> 
</servlet-mapping> 
<context-param> 
    <param-name>facelets.DEVELOPMENT</param-name> 
    <param-value>true</param-value> 
</context-param> 

<!-- Primefaces --> 
<servlet> 
    <servlet-name>Resource Servlet</servlet-name> 
    <servlet-class>org.primefaces.resource.ResourceServlet</servlet-class> 
</servlet> 
<servlet-mapping> 
    <servlet-name>Resource Servlet</servlet-name> 
    <url-pattern>/primefaces_resource/*</url-pattern> 
</servlet-mapping> 

<context-param> 
    <param-name>javax.faces.PROJECT_STAGE</param-name> 
    <param-value>Production</param-value> 
</context-param> 
<context-param> 
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name> 
    <param-value>server</param-value> 
</context-param> 
<context-param> 
    <param-name>primefaces.THEME</param-name> 
    <param-value>bluesky</param-value> 
</context-param> 
<filter> 
    <filter-name>PrimeFaces FileUpload Filter</filter-name> 
    <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class> 
    <init-param> 
     <param-name>thresholdSize</param-name> 
     <param-value>5120</param-value> 
    </init-param> 
    <init-param> 
     <param-name>uploadDirectory</param-name> 
     <param-value>/****</param-value> 
    </init-param> 
</filter> 
<filter-mapping> 
    <filter-name>PrimeFaces FileUpload Filter</filter-name> 
    <servlet-name>Faces Servlet</servlet-name> 
</filter-mapping> 


<!-- security --> 

<login-config> 
    <auth-method>FORM</auth-method> 
    <realm-name>file</realm-name> 
    <form-login-config> 
     <form-login-page>/login.xhtml</form-login-page> 
     <form-error-page>/error.xhtml</form-error-page> 
    </form-login-config> 
</login-config> 

<security-role> 
    <role-name>epsadmin</role-name> 
</security-role> 
<security-constraint> 
    <web-resource-collection> 
     <web-resource-name>Admin</web-resource-name> 
     <url-pattern>/*</url-pattern> 
    </web-resource-collection> 
    <auth-constraint> 
     <role-name>admin</role-name> 
    </auth-constraint> 
</security-constraint> 

<security-constraint> 
    <display-name>Restrict raw XHTML documents</display-name> 
    <web-resource-collection> 
     <web-resource-name>XHTML</web-resource-name> 
     <url-pattern>*.xhtml</url-pattern> 
    </web-resource-collection> 
    <auth-constraint /> 
</security-constraint> 

업데이트 전체의 web.xml에게 있습니다. 이이이이이 출력

csman/javax.faces.resource/primefaces.js.jsf?ln=primefaces&v=3.1-SNAPSHOT 

버튼을 제출 누를 때 내가 얻을 URL 지금 전체의 web.xml

<servlet> 
    <servlet-name>Faces Servlet</servlet-name> 
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class> 
    <load-on-startup>1</load-on-startup> 
</servlet> 
<servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.jsf</url-pattern> 
</servlet-mapping> 

<context-param> 
    <param-name>facelets.DEVELOPMENT</param-name> 
    <param-value>true</param-value> 
</context-param> 

<context-param> 
    <param-name>javax.faces.PROJECT_STAGE</param-name> 
    <param-value>Production</param-value> 
</context-param> 
<context-param> 
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name> 
    <param-value>server</param-value> 
</context-param> 
<context-param> 
    <param-name>primefaces.THEME</param-name> 
    <param-value>bluesky</param-value> 
</context-param> 
<filter> 
    <filter-name>PrimeFaces FileUpload Filter</filter-name> 
    <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class> 
    <init-param> 
     <param-name>thresholdSize</param-name> 
     <param-value>5120</param-value> 
    </init-param> 
    <init-param> 
     <param-name>uploadDirectory</param-name> 
     <param-value>/tempupload</param-value> 
    </init-param> 
</filter> 
<filter-mapping> 
    <filter-name>PrimeFaces FileUpload Filter</filter-name> 
    <servlet-name>Faces Servlet</servlet-name> 
</filter-mapping> 


<welcome-file-list> 
    <welcome-file>home.jsf</welcome-file> 
</welcome-file-list> 


<login-config> 
    <auth-method>FORM</auth-method> 
    <realm-name>file</realm-name> 
    <form-login-config> 
     <form-login-page>/login.jsf</form-login-page> 
     <form-error-page>/error.jsf</form-error-page> 
    </form-login-config> 
</login-config> 

<security-role> 
    <role-name>admin</role-name> 
</security-role> 
<security-constraint> 
    <web-resource-collection> 
     <web-resource-name>Admin</web-resource-name> 
     <url-pattern>*.jsf</url-pattern> 
    </web-resource-collection> 
    <auth-constraint> 
     <role-name>admin</role-name> 
    </auth-constraint> 
</security-constraint> 

<error-page> 
    <error-code>403</error-code> 
    <location>/errorpages/error403.jsf</location> 
</error-page> 
<error-page> 
    <error-code>404</error-code> 
    <location>/errorpages/error404.jsf</location> 
</error-page> 
<error-page> 
    <error-code>500</error-code> 
    <location>/errorpages/error500.jsf</location> 
</error-page> 
<error-page> 
    <exception-type>com.*******.ApplicationException</exception-type> 
    <location>/errorpages/error500.jsf</location> 
</error-page> 

입니다.

PrimeFaces={escapeClientId:function(a){return"#"+a ..........etc 

그러나 시작 URL에 다시 연결하면 home.jsf 페이지로 연결됩니다. 로그인 절차가 정상적으로 진행되었습니다.

login.jsf 페이지에는 JSF 태그가 표시되지만 스킨되지 않은 것은 아닙니다.

이상한?!

+0

페이지에 jquery 참조/선언을 추가해 주시겠습니까? * .html은 FacesServlet에서 처리해야합니다. – oers

+0

jquery 참조가 없으므로 Primeface 만 사용합니다. 이상한 권리? 그리고 * .html (테스트 용)을 추가하면 primefaces css 파일로 전달됩니다. –

+0

자원 서블릿 내용을 제거하려고 시도합니다. 이것은 primefaces 2.0 안내서에서 나온 것으로 보이며 3.1에는 필요하지 않습니다. http://primefaces.org/gettingStarted.html – oers

답변

3

당신은 *.jsf URL을 청취 할 FacesServlet을 구성했습니다. 따라서 로그인 및 오류 페이지가 해당 URL을 가리 키도록 변경하면됩니다.

그래서, 다른 대답에 의해 제안

<form-login-page>/login.xhtml</form-login-page> 
<form-error-page>/error.xhtml</form-error-page> 

<form-login-page>/login.jsf</form-login-page> 
<form-error-page>/error.jsf</form-error-page> 

에이 FacesServlet에 추가 *.xhtml URL 패턴을 제거 하는 것을 잊지 마세요 변경합니다. <security-constraint>*.xhtml에 있으며 원시 소스를보고있는 최종 사용자를 차단하며 이는 함께 잘 작동하지 않습니다. 다른 대안으로

<servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.jsf</url-pattern> 
</servlet-mapping> 
, *.xhtml

<servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.xhtml</url-pattern> 
</servlet-mapping> 

에 의해*.jsf에 매핑을 교체하고 모든 URL에 *.xhtml를 사용하는 스틱 : 그래서 당신의 FacesServlet 매핑 이 있어야한다/귀하의 웹 사이트 전반에 걸친 링크 및 을 삭제<security-constraint>*.xhtml. *.xhtml에 대한 매핑을 사용하면 최종 사용자는 원시 소스를 볼 수 없습니다. 모든 단일 XHTML 파일은 FacesServlet을 통해 전달됩니다. 구체적인 문제에 관련없는


, 다른 질문에 대한 귀하의 의견에 따라 당신은 인덱스 페이지에 메타 새로 고침을 갖고있는 것 같다. 이것은 거의 의미가 없습니다. <welcome-file-list><welcome-file>home.xhtml</welcome-file>을 추가하기 만하면됩니다. *.xhtmlFacesServlet을 매핑하면 정상적으로 작동합니다.

+0

이것도 작동하지 않습니다 ??? 업데이트 된 질문의 전체 web.xml을 참조하십시오. –

+0

최종 사용자의 관점에서 의미가없는 "작동하지 않음"을 말하는 대신 개발자의 관점에서 증상을 설명하십시오. 어떤 방법을 시도해 봤습니까? 다른 변경 사항도 취소 했습니까? JSF 1.x의 특정 컨텍스트 매개 변수를 사용하더라도 (* .xhtml에 매핑하면 작동하지 않습니다.) PrimeFaces 2.x를 사용하기 때문에 JSF 2.x를 사용하고 있다고 가정합니다. JSF 1.x에서). – BalusC

+0

안녕하세요 BalusC, 이전에 구성을 게시했습니다. Seam2를 많이 사용했기 때문에 오래된 설정 부분이있었습니다. 나중에 JSF2로 옮겼습니다. 내 새로운 web.xml을 참조하십시오. –

2

login.xhtmlFacesServlet으로 처리되지 않습니다. *.jsf 파일 만 처리합니다.
xhtml도 매핑해야합니다. 2.4까지 서블릿 - 투기를 들어

:

서블릿 사양이 들어
<servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.jsf</url-pattern> 
</servlet-mapping> 
<servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.xhtml</url-pattern> 
</servlet-mapping> 

.5 최대 :

<servlet-mapping> 
     <servlet-name>Faces Servlet</servlet-name> 
     <url-pattern>*.jsf</url-pattern> 
     <url-pattern>*.xhtml</url-pattern> 
    </servlet-mapping> 
+0

고마워! 여러 URL 패턴을 매핑 할 수 있는지 몰랐습니다. –

+0

아니면' /login.jsf'를 사용하십시오. – BalusC

+0

음, 작동하지 않는 것 같습니다. /*을 추가하고 제출 버튼을 클릭하면 다음 url http : //myserver/myapp/*/javax.faces.resource/primefaces.js? ln = primefaces & v = 3.1- SNAPSHOT –

관련 문제