我刚刚开始使用EJB。我想使用JTA从数据库中接收一些数据。 我的实体:
@Entity
@Table(name = "User")
@NamedQuery(name = "User.findByAddressName",
query = "select u from User u where u.userAddress.addressName = :addressName")
public class User implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private long userID;
@Column(name = "userFirstName", length = 45)
private String userFirstName;
@Column(name = "userLastName", length = 45)
private String userLastName;
@Column(name = "userBirthDate")
private Date userBirthDate;
@Column(name = "userPhone")
private String userPhone;
@Column(name = "userPassword")
private String userPassword;
@OneToOne(cascade = CascadeType.ALL, mappedBy = "addressUser")
private Email userAddress;
public User() {
}
public User(String userFirstName, String userLastName, Date userBirthDate, String userPhone, String userPassword) {
this.userFirstName = userFirstName;
this.userLastName = userLastName;
this.userBirthDate = userBirthDate;
this.userPhone = userPhone;
this.userPassword = userPassword;
}
}
我的道:
@Stateless
public class UserBean {
@PersistenceContext(unitName = "server")
private EntityManager em;
public User getUserByEmail(String email) {
TypedQuery<User> queryUser = em.createNamedQuery("User.findByAddressName",
User.class);
queryUser.setParameter("addressName", email);
return queryUser.getSingleResult();
}
}
我的服务:
@Stateless
public class LoginService {
@EJB
UserBean userBean;
public boolean loginUser(String userEmail, String userPass) {
User user = userBean.getUserByEmail(userEmail);
if (userPass.equals(user.getUserPassword())) {
return true;
} else return false;
}
}
我尝试接收数据:
boolean b = new LoginService().loginUser("user", "user1");
但是,在LoginService中由@EJB注入的UserBean userBean为空。
有很多关于如何做这些事情的简单例子,我做的都完全相同,但它仍然抛出NullPointerException,我不知道为什么。
答案 0 :(得分:1)
要从Java EE环境中的注入中受益,您无法通过new
实例化您的服务。您需要通过@EJB
注入它或使用JNDI查找它。
如果您通过new
创建服务,则此实例不会被视为容器管理的实例,因此其所有功能(如注入)都不可用。当您通过JNDI注入或查找其引用时,您可以获得完全托管的实例,并为您完成所有注入。
不知道您所在的Java EE堆栈(5或6),但请记住,您不能简单地通过@EJB
将内容注入手工创建的类中。它们也需要由容器创建以利用注射。