- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下类(class):
A类
import java.io.Serializable;
import javax.enterprise.context.SessionScoped;
import javax.inject.Inject;
import javax.inject.Named;
import javax.persistence.EntityManager;
import timereport.db.UserBean;
import timereport.utils.JPAUtil;
@Named("classA")
@SessionScoped
public class ClassA implements Serializable {
@Inject
protected UserBean userBean;
public void logout() {
userBean = null;
}
public void login() {
EntityManager em = JPAUtil.getEntityManagerFactory().createEntityManager();
userBean = em.find(UserBean.class, userBean.getUsername());
}
//setter and getter for userBean
}
login()
我在做
EntityManager em = JPAUtil.getEntityManagerFactory().createEntityManager();
userBean = em.find(UserBean.class, userBean.getUsername());
UserBean
对象,这是正确的。问题来了……
import java.io.Serializable;
import java.lang.annotation.Annotation;
import java.sql.Date;
import java.util.List;
import java.util.ResourceBundle;
import javax.enterprise.context.SessionScoped;
import javax.faces.application.FacesMessage;
import javax.faces.context.FacesContext;
import javax.inject.Inject;
import javax.inject.Named;
import javax.persistence.EntityManager;
import javax.persistence.Query;
import org.apache.log4j.Logger;
import timereport.db.UserBean;
import timereport.ClassB;
import timereport.utils.JPAUtil;
@Named("classB")
@SessionScoped
public class ClassB implements Serializable {
@Inject private UserBean userBean;
String throughUserBean = userBean.getUsername();
...
}
import java.io.Serializable;
import javax.enterprise.context.SessionScoped;
import javax.inject.Named;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
import com.proxiad.timereport.utils.AESEncryptDecryptUtil;
@Named("user")
@SessionScoped
@Entity
@Table(name="t_user")
public class UserBean implements Serializable{
/**
*
*/
private static final long serialVersionUID = -56986575421886097L;
@Id
@Column(name="username")
private String username;
@Column(name="fullname")
private String fullname;
@Column(name="password")
private String password;
@Column(name="email")
private String email;
@ManyToOne(cascade={CascadeType.ALL})
@JoinColumn (name="department", referencedColumnName="value")
private ReferenceDataBean department;
@ManyToOne(cascade={CascadeType.ALL})
@JoinColumn(name="role", referencedColumnName="value")
private ReferenceDataBean role;
public UserBean() {}
public String getFullname() {
return fullname;
}
public void setFullname(String fullname) {
this.fullname = fullname;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
try {
this.password = AESEncryptDecryptUtil.encrypt(password);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public ReferenceDataBean getDepartment() {
return department;
}
public void setDepartment(ReferenceDataBean department) {
this.department = department;
}
public ReferenceDataBean getRole() {
return role;
}
public void setRole(ReferenceDataBean role) {
this.role = role;
}
@Override
public int hashCode() {
return getUsername().hashCode() + 17 * getEmail().hashCode();
}
@Override
public boolean equals(Object obj) {
if (obj instanceof UserBean) {
UserBean user = (UserBean) obj;
if (getUsername().equals(user.getUsername()) && getEmail().equals(user.getEmail())) {
return true;
}
}
return false;
}
@Override
public String toString() {
return String.format("Username: %s\nEmail: %s\nDepartment:\n%s\nRole:\n%s\n",
getUsername(), getEmail(), getDepartment(), getRole());
}
}
最佳答案
注入(inject)发生 之后 build 。注入(inject)的属性在施工期间不可用。访问注入(inject)属性的最早点是 @PostConstruct
方法。
所以,更换
@Inject private UserBean userBean;
String throughUserBean = userBean.getUsername();
@Inject private UserBean userBean;
String username;
@PostConstruct
public void init() {
username = userBean.getUsername();
}
@Inject ClassB
没有意义,所以我删除了它。
关于java - 通过 FacesContext 获取 SessionScoped Bean 的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8255951/
我正在检查 this template 的代码来自 OmniFaces Showcase app ,当我遇到一个p:selectOneMenu中使用的以下条件时: disabled="#{facesC
我想在 Websphere 上部署一个企业项目。 我得到以下异常。 可能是什么原因? [03.09.12 11:21:05:636 CEST] 0000001a webapp E com
我正在集成 SWF 2.2.1、Primefaces 2.2.1、JSF 2、Spring Security 3、Spring 3.1.0M1。我能够访问 Spring web-flow xml 中提
当我点击应用程序 URL (http://localhost:9082/pages/upload.jsf) 时,浏览器上只显示“Error:500 StackOverflowError”。根据我在这个
当我点击应用程序 URL (http://localhost:9082/pages/upload.jsf) 时,浏览器上只显示“Error:500 StackOverflowError”。根据我在这个
如何在过滤器中检索 FacesContext? 我遵循以下关于如何检索 FacesContext 的文章在 Filter : http://ocpsoft.org/java/jsf-java/jsf-
FacesContext 有何用途? 它具体是在哪里实现的? 最佳答案 引自JSF 2.0 specification第6.1章: FacesContext JSF defines the javax
嗨, 这个问题来自之前的answered提问者 BalusC 。答案摘录如下: This happens only if under the covers a forward by RequestDi
我的jsp页面是:主页.jsp Insert title here Employee Management P
在我的 previous question我遇到了从登录表单显示验证消息的问题。该问题现已解决,但这次我无法显示带有 FacesContex#addMessage 的自定义消息. 使用 JSF + P
莫哈拉 2.2.12 这是接管 FacesContext 实例化的一段代码: FacesContext context = facesContextFactory.getFacesContext
我试图通过在FacesContext类的FacesContext.getCurrentInstance()方法中调用run()来获取Runnable,但它返回null。 public class Ta
同时通过javadoc of FacesContext ,我遇到了这句话 The instance remains active until its release() method is calle
我已经在 Icefaces 论坛上问过这个问题,但同时我意识到这是一个更通用的问题。 当我在 MDB 中收到消息时,我想更新 JSF 页面的某些部分。 问题是,如何从 EJB 容器中获取 FacesC
无法在自生成的线程中获得“FacesContext.getCurrentInstance()”。 需要根据后端流程动态更新组件。通过创建一个线程来监视进程并与 p:poll 一起回调组件更新来实现相同
这个问题在这里已经有了答案: Can I update a JSF component from a JSF backing bean method? (5 个回答) 5年前关闭。 实际上,当出现 k
我正在尝试向 JSF 应用程序添加一些单元测试。此应用程序没有严重依赖任何最佳实践,因此许多服务方法使用 FacesContext从托管 session bean 中提取数据,如下所示: (这是在一个
我有一个问题。我需要知道我的页面是否存在全局错误。这是因为我有 2 个不同的 h:messages (错误容器) 一个将显示业务相关消息,另一个将仅显示验证消息。由于业务需求,有两条消息。 当生成
我在两台不同的机器上有相同的代码。一个在工作,另一个没有!代码在这里...你能发现我错过了什么吗? public void urlParameters() { FacesContext con
问题如下:我需要序列化用户 session ,因此,在服务器重新启动后它仍然存在。 使用 JavaEE 和 Tomcat 7 与 implements Serialized 配合使用效果很好,但问题在
我是一名优秀的程序员,十分优秀!