Из той же ветки похоже, что Payara применила исправление, не дожидаясь выпуска 2.3.10. Решает ли обновление до исправленной Payara проблему для вас?

ьзование Payara Server 4.1.2.174 с мохаррой 2.2.15.

У меня есть простой Именованный Бин с областью действия javax.faces.view.ViewScoped.

import java.io.Serializable;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.annotation.PostConstruct;
import javax.faces.view.ViewScoped;
import javax.inject.Named;


@Named
@ViewScoped
public class SimpleBean implements Serializable
{
    private final Logger logger = Logger.getLogger(SimpleBean.class.getName());

    @PostConstruct
    private void init()
    {
        logger.log(Level.SEVERE, "{0}.init()", this);
    }

    private String name;

    public String getName()
    {
        return name;
    }

    public void setName(String name)
    {
        this.name = name;
    }

    public String action()
    {
        logger.log(Level.SEVERE, "{0}.action()", this);
        logger.log(Level.SEVERE,"====================");
        logger.log(Level.SEVERE, "name: {0}", getName());
        logger.log(Level.SEVERE,"====================");
        return "submit";
    }
}

Итак, у меня есть простая страница index.xhtml с формой.

<h:form>
  <h:inputText value="#{simpleBean.name}"></h:inputText>
  <h:link value="To submit" outcome="submit"/>
  <h:commandButton value="Welcome Me" action="#{simpleBean.action()}"/>
</h:form>

Я могу открыть index.xhtml в двух разных вкладках или окнах браузера. Итак, у меня есть следующий журнал:

Severe: [email protected]()
Finest: Handling PostConstructViewMapEvent
Finest: Handling PreDestroyViewMapEvent
Finest: Destroying @viewscoped beans from view map: {simpleBean=solvo.ee.beans.SimpleBean@2adafd68}
Severe: [email protected]()
Finest: Handling PostConstructViewMapEvent
Finest: Handling PreDestroyViewMapEvent
Finest: Destroying @viewscoped beans from view map: {simpleBean=solvo.ee.beans.SimpleBean@49a86248}

Как мы видим, есть два разных экземпляра SimpleBean. После этого я отправляю форму первой вкладки.

Severe: [email protected]()
Severe: ====================
Severe: name: First tab
Severe: ====================
Finest: Handling PreDestroyViewMapEvent
Finest: Destroying @viewscoped beans from view map: {simpleBean=solvo.ee.beans.SimpleBean@2adafd68}
Finest: Handling PreDestroyViewMapEvent
Finest: Destroying @viewscoped beans from view map: {}

Если я попытаюсь отправить форму второй вкладки, сохраненный ранее экземпляр SimpleBean (solvo.ee.beans.SimpleBean@49a86248) не будет использован, вместо этого ViewScopeContextManager создаст новый экземпляр класса SimpleBean, как мы можем видеть в журнал:

Severe: [email protected]()
Severe: [email protected]()
Severe: ====================
Severe: name: Second tab
Severe: ====================
Finest: Handling PreDestroyViewMapEvent
Finest: Destroying @viewscoped beans from view map: {simpleBean=solvo.ee.beans.SimpleBean@4797f115}
Finest: Handling PreDestroyViewMapEvent
Finest: Destroying @viewscoped beans from view map: {}

Я проверил код метода com.sun.faces.application.view.ViewScopeContextManager.copyViewScopeContextsFromSession и, насколько я понимаю, это поведение является нормальным. Однако, если я сохраню параметры запроса или другие важные данные в моем компоненте, я потеряю его, потому что экземпляр будет потерян после отправки первой формы.

Есть ли решение сохранить бин в первую очередь связанным со второй вкладкой (в моем примере solvo.ee.beans.SimpleBean@49a86248)?

Ответы на вопрос(1)

Ваш ответ на вопрос