“@inject”-ed属性保持为null

时间:2011-04-14 09:22:51

标签: java java-ee dependency-injection java-ee-6 javabeans

我正在尝试将服务注入到我的bean中,但它总是null。 我收到以下错误:WELD-001000错误解析属性userBean对基础null。

一些代码段:

的index.xhtml

<h:body>
    Hello from Facelets
    #{userBean.name}
</h:body>

userbean.java

package beans;

import Domain.User;
import java.io.Serializable;
import javax.enterprise.context.SessionScoped;
import javax.inject.Inject;
import javax.inject.Named;
import service.UserService;

@Named
@SessionScoped
public class UserBean implements Serializable{
    @Inject UserService service;
    private User user;

    public UserBean(){
        this.user = service.find_user("foo");
    }

    public String getName(){
        return "bar";
    }
}

UserService.java

package service;

import Domain.User;
import javax.ejb.Stateless;
import javax.inject.Named;

@Named
@Stateless
public class UserService {
    public UserService(){}

    public User find_user(String name){
        return new User();
    }
}

2 个答案:

答案 0 :(得分:8)

错误消息可能是一个提示,JVM无法创建UserBean的实例。以下是一些猜测,必须证明:

Dependecy Injection需要一个依赖注入器,一个将<{1}}的实例注入<{1}}的工具到UserService。在你的代码中,你已经在bean的实例化过程中使用了这个注入的实例:你在构造函数中调用注入的服务。

如果依赖注入器在创建bean之后启动它的工作然后对构造函数内的服务的调用将引发一个{ {1}}(因为当时UserBean仍为NullPointerException)。通过尝试在service构造函数中捕获NPE一段时间来检查它是值得的。如果你抓住了一个 - 瞧 - 依赖注入器在创建bean之后开始运行,因此,我们不能在类实例化期间使用注入的服务(=在构造函数中)


解决方法的想法:实现一个小型服务提供者帮助程序类 - 内部类可以工作:

null

未经测试但可以正常工作 - 在中使用bean构造函数之前,应该在提供程序类中注入服务。

答案 1 :(得分:8)

另一种选择是使用@PostConstruct方法注释。

@SessionScoped
public class UserBean implements Serializable {
    @Inject UserService service;
    private User user;
    public UserBean() {

    }

   @PostConstruct
    void init(){
        this.user = service.findUser("kaas"); 
    }

  }

阅读docs