我希望为一些托管bean创建一个超类,其中除其他外还包含注入的@SessionScoped托管bean和@EJB。以下作品
超类:
@ManagedBean
@ViewScoped
public abstract class UserPageController implements Serializable {
private static final long serialVersionUID = -6118448960678133445L;
@ManagedProperty(value = "#{sessionController}")
protected SessionController sessionController;
private User user;
private String userId;
@EJB protected UserBean userBean;
public UserPageController() {
}
public SessionController getSessionController() {
return sessionController;
}
public void setSessionController(SessionController sessionController) {
this.sessionController = sessionController;
}
//-------------------------------- User ------------------------------------
public String getUserId() {
return userId;
}
public void setUserId(String userId) {
this.userId = userId;
}
public User getUser() {
if (user == null) {
if (getUserId() != null && sessionController.getLoggedInUser().getRole().isManager()) {
User dbUser = userBean.findUser(Long.parseLong(userId));
if (dbUser != null) {
setUser(dbUser);
}
} else {
setUser(userBean.findUser(sessionController.getLoggedInUser().getId()));
}
}
return user;
}
public void setUser(User user) {
this.user = user;
}
}
用法:
@ManagedBean
@ViewScoped
public class UserCompetenceController extends UserPageController implements Serializable {
// Stuff that uses sessionController & userBean.
}
有什么方法可以避免将抽象超类注释为托管bean?感觉有点不对劲,但是如果没有它,依赖注入将无法工作。
最佳答案
我要说的是,即使您最终得到一个从其基类继承字段的类,也要为该类分别进行注入,这意味着要正常工作,还必须对基类进行注释-但这是只是一个猜测。
您是否使用CDI尝试过相同的构造?