H: сообщения не отображаются при нажатии кнопки p: commandButton

У меня проблема с тегом h: messages в JSF, который просто не показывает никаких сообщений. В журнале Glassfish нет ошибок при нажатии кнопки. Настройка выполняется следующим образом:

test.xhtml:

<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:p="http://primefaces.org/ui" 
    xmlns:j="http://primefaces.org/ui"
xmlns:f="http://java.sun.com/jsf/core">
<h:head>
    <title>test</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</h:head>
<h:body>
    <h:messages globalOnly="true"/>
    <h:form id="loginform">         
        <p:commandButton id="testButton" value="Test"
          action="#{loginSessionBean.test()}" />
    </h:form>
</h:body>
</html>

С SessionScopedBean:

@ManagedBean
@SessionScoped
public class LoginSessionBean implements Serializable {

private static final long serialVersionUID = 1L;
...
public String test(){
     FacesContext fc = FacesContext.getCurrentInstance();
     fc.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_WARN, "Test!", null)); 
    return "";
}

Ответы

Ответ 1

Вы отправляете запрос ajax с помощью PrimeFaces <p:commandButton>. Запросы Ajax по умолчанию не имеют обратной связи (если только не используется PrimeFaces autoUpdate="true"). Вы должны явно указывать части представления, которые вы хотите обновить при ответе ajax.

Один из способов - указать атрибут update на <p:commandButton>, чтобы указать идентификатор клиента компонента <h:messages>.

<h:messages id="messages" ... />
<h:form>         
    <p:commandButton ... update=":messages" />
</h:form>

Другой способ - заменить его на PrimeFaces <p:messages>, который имеет атрибут autoUpdate для автоматического обновления ответа ajax.

<p:messages ... autoUpdate="true" />
<h:form>         
    <p:commandButton ... />
</h:form>

Совершенно другая альтернатива - отключить ajax, добавив к кнопке атрибут ajax="false", таким образом будет выполняться синхронная обратная передача, которая эффективно приводит к полному обновлению страницы, точно так же, как ведет себя стандартный JSF <h:commandButton> при использовании без <f:ajax>.

<h:messages ... />
<h:form>         
    <p:commandButton ... ajax="false" />
</h:form>

См. также: