2

我对 JSF 很陌生,并没有真正“习惯”不同的想法,所以我在(我认为)是基本的东西上苦苦挣扎。

假设我有一个类 User,它是一个会话 bean。

假设我有一个包含 10000 个对象的控制器,比如 Factory,它需要能够将其中一些对象设置为“锁定”,在我们的例子中,这意味着“锁定”字段不再变为 null,而是引用“LockedItem”目的。

这是我无法让事情正常工作的地方:LockedItem,当你实例化它时,应该引用当前登录的用户。我应该怎么做?

我尝试使用@managedproperty 进行注入,但在LockedItem.constructor 中它为空(我认为这是正常的)然后我尝试了@PostConstruct 方法,但从未调用过该方法(为什么?即使我将其设为托管bean ... postconstruct 方法是否仅在“.xhtml”创建对象时调用?)或者我应该使用“java se”技巧,比如使用户静态?


澄清为什么不调用 @PostConstruct 的代码(“Seat”之一):

.xhtml

<h:outputLabel id="user" value="Hello #{user.name}" />
<h:outputLabel id="car" value="you have #{car.brand}" />

用户

package test;

import java.io.Serializable;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;

@ManagedBean
@SessionScoped
public class User implements Serializable {
    private String name ;

    public User()
    {
        name = "toto"; 
        System.out.println("User constructor");
    }

    public String getName() {
        return name;
    }

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


}

package test;

import java.io.Serializable;

import javax.faces.bean.ManagedBean;

@ManagedBean
public class Car implements Serializable {
    private String brand ;
    private Seat seat ;

    public Car()
    {
        brand = "audi" ;
        seat = new Seat();
        System.out.println("Car constructor") ;
    }

    public String getBrand() {
        return brand;
    }

    public void setBrand(String brand) {
        this.brand = brand;
    }


}

座位

package test;

import java.io.Serializable;

import javax.annotation.PostConstruct;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ManagedProperty;

@ManagedBean
public class Seat implements Serializable {
    private int nb ;
    private String userName ;

    @ManagedProperty("#{user}")
    private User user ;

    public Seat()
    {
        nb = 4 ;
        userName="na";
        System.out.println("! Seat constructor ") ;
    }

    @PostConstruct
    public void init()
    {
        System.out.println("!! Seat postconstruct : "+user.getName());
    }

    public User getUser() {
        return user;
    }

    public void setUser(User user) {
        this.user = user;
    }

    public int getNb() {
        return nb;
    }

    public void setNb(int nb) {
        this.nb = nb;
    }
}

谢谢 !

4

1 回答 1

5

@PostConstruct是正确的方法。

如果您使用new运算符自己实例化 bean(显然),则不会调用它。仅当 JSF 在 EL 上下文中第一次引用它时实例化和管理 bean 本身时才调用它,就像这样#{bean}。这确实通常发生在视图端,但这也可能发生在模型/控制器旁边@ManagedProperty("#{bean}")or Application#evaluateExpressionGet()

你绝对不应该做User静态。它将在应用程序范围内共享,而不是在会话范围内共享。

另一种方法是只传递当前User作为构造函数的参数,或者自己LockedItem调用初始化方法,以确保该类根本不代表合法的 JSF 支持 bean。

于 2012-09-07T15:07:17.427 回答