Страница входа, управляемая контейнером, не отображает компоненты JSF - PullRequest
2 голосов
/ 27 января 2012

Я искал решение, но не смог найти ответ на свой вопрос. У меня есть страница login.xhtml, но теги JSF не отображаются. При успешном входе в систему теги отображаются правильно. так что каким-то образом login.xhtml не проходит через сервлет face. Это кажется странным, потому что все настроено правильно. Как заставить файл login.xhtml правильно отображаться?

Вот моя часть web.xml

<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-форма отображается правильно, а компоненты шаблона - нет. Выход:

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

Обновление 31 января 2012 года

Конфигурация: Glassfish 3.1 Primefaces 3.1 JSF 2.1

У меня есть страница index.html, которая пересылается на home.jsf. Но контейнер замечает, что пользователь не вошел в систему, поэтому он перенаправляет на login.xhtml.

Если я добавляю только * .jsf в web.xml, все работает нормально, но login.jsf не отображает теги JSF.

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

Если я также добавлю * .xhtml, то на странице login.jsf отображаются теги, но не в соответствии со скином Primefaces. Когда я нажимаю "Отправить", на экран выводится файл jquery.js.

Вот полный 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>
    <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>

Обновление после ответа 2 от BalusC. Теперь это полный 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>

Это URL, который я получаю при нажатии кнопки отправки

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

Это вывод.

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

Однако, когда я снова нажимаю «Подключиться к начальному URL», я успешно перенаправляюсь на страницу home.jsf. Итак, процедура входа прошла успешно.

Не то, чтобы на странице login.jsf отображались теги JSF, но они не имеют скинов.

Weird?!

Ответы [ 2 ]

3 голосов
/ 31 января 2012

Вы настроили FacesServlet для прослушивания *.jsf URL.Поэтому все, что вам нужно сделать, это изменить страницы входа и ошибки, чтобы они указывали именно на этот 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>

Донне забудьте удалить дополнительный шаблон *.xhtml URL на FacesServlet, как это предлагается в другом ответе.У вас есть <security-constraint> на *.xhtml, чтобы блокировать конечных пользователей, видящих необработанный источник, и это не будет хорошо работать вместе.Таким образом, ваше FacesServlet отображение должно иметь только this:

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

В качестве другой альтернативы заменить отображение на *.jsf на *.xhtml

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

и продолжайте использовать *.xhtml во всех URL / ссылках на вашем сайте и удалить <security-constraint> на *.xhtml.При отображении на *.xhtml конечные пользователи никогда не увидят необработанный источник.Каждый отдельный файл XHTML будет проходить через FacesServlet.


Не связанный с конкретной проблемой, согласно вашему комментарию к другому вопросу, который, по-видимому, имеет мета-обновлениестраница указателя.Это имеет мало смысла.Просто добавьте <welcome-file>home.xhtml</welcome-file> к <welcome-file-list>.Это прекрасно работает, если вы сопоставили FacesServlet на *.xhtml.

2 голосов
/ 27 января 2012

Ваш login.xhtml не будет обрабатываться FacesServlet.Вы обрабатываете только файлы *.jsf.
Вам также необходимо отобразить xhtml.

Для Servlet-Spec до 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>

Для Servlet-Spec 2.5 иup:

   <servlet-mapping>
        <servlet-name>Faces Servlet</servlet-name>
        <url-pattern>*.jsf</url-pattern>
        <url-pattern>*.xhtml</url-pattern>
    </servlet-mapping>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...