해결책을 찾았지만 내 특정 문제에 대한 답을 찾을 수 없습니다. 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 태그가 표시되지만 스킨되지 않은 것은 아닙니다.
이상한?!
페이지에 jquery 참조/선언을 추가해 주시겠습니까? * .html은 FacesServlet에서 처리해야합니다. – oers
jquery 참조가 없으므로 Primeface 만 사용합니다. 이상한 권리? 그리고 * .html (테스트 용)을 추가하면 primefaces css 파일로 전달됩니다. –
자원 서블릿 내용을 제거하려고 시도합니다. 이것은 primefaces 2.0 안내서에서 나온 것으로 보이며 3.1에는 필요하지 않습니다. http://primefaces.org/gettingStarted.html – oers