为什么@PostConstruct不起作用?

3

我有一个简单的EJB,当我通过独立的客户端运行它时,一切正常, 但是一旦我添加拦截器,EJB中的@PostConstruct就停止工作了:

包括拦截器;

public class LogInterceptor {

@PostConstruct
public void init(InvocationContext context) {
    System.out.println(new Date().toString() +" Entered interceptor");
}

@PreDestroy
public void aboutToBeRemoved(InvocationContext context) {
    System.out.println(new Date().toString() + " Leaving interceptor");
}

@AroundInvoke
public Object gettingToBusiness(InvocationContext context) {

    String methodName = context.getMethod().getName();
    System.out.println("The method name is: " +methodName);

    if (methodName.equals("add")) {

    }
    try {
        return context.proceed();
    } catch (Exception e) {
        e.printStackTrace();
    }
    return null;
}


}

我的测试客户端:

public class Test {

public static void main(String[] args){
    InitialContext ctx=getInitialContext();
    ListRemote stub=null;
    try {
        stub = (ListRemote)ctx.lookup("ejb:/Lab12/ListEJB!interceptor.ListRemote?stateful");
    } catch (NamingException e) {
        System.out.println("Lookup Failed");
        e.printStackTrace();
    }
    System.out.println("Adding data");
    stub.add("Hello");
    stub.add("-");
    stub.add("World");
    stub.add("!!!");
    System.out.println("Getting data :");
    for(Object o:stub.getAll()){
        System.out.print(o+" ");
    }
    System.out.println("Removing '-' element");
    stub.remove(1);
    System.out.println("Getting data again:");
    for(Object o:stub.getAll()){
        System.out.print(o+" ");
    }
    stub.destroy();
}

public static InitialContext getInitialContext(){
    Properties properties = new Properties();
    properties.put(Context.URL_PKG_PREFIXES , "org.jboss.ejb.client.naming");
            try {
        return new InitialContext(properties);
    } catch (NamingException e) {
        System.out.println("Cannot generate InitialContext");
        e.printStackTrace();
    }
    return null;
}
}

我的 EJB:

@Stateful(name="ListEJB")
@Interceptors({LogInterceptor.class})
public class ListBean implements ListRemote{
private ArrayList<Serializable> list;

@PostConstruct
public void init(){
    System.out.println("In it init ---------------------------------------------------");
    list=new ArrayList<Serializable>();
}
public void add(Serializable object){
    System.out.println("Currently in the list is: " +list);

    System.out.println("The object is: " +object);
    list.add(object);
    System.out.println("Added");
}
public Serializable get(int index){
    return list.get(index);
}
public void remove(int index){
    list.remove(index);
}
public Object[] getAll(){
    return list.toArray();
}
@Remove
public void destroy(){
    list=null;
}

}

为什么它会禁用我的EJB @PostConstruct方法?

什么意思,它不工作?它没有被调用? - Eugene
是的,它没有被调用。 - Dani Gilboa
谁将处理@PostConstruct?你没有容器。 - Eugene
@Eugene 根据代码看来,它似乎在 JBoss 容器中。 - eis
1个回答

3
在这段代码中:
@PostConstruct
public void init(InvocationContext context) {
    System.out.println(new Date().toString() +" Entered interceptor");
}

您正在拦截原始EJB的PostConstruct方法并阻止其执行。如果您想将它传递给目标EJB,需要调用proceed方法:
@PostConstruct
public void init(InvocationContext context) {
    System.out.println(new Date().toString() +" Entered interceptor");
    context.proceed();
}

同样适用于您的PreDestroy。基本上适用于所有拦截方法。请参见EJB3规范,第12.5节(第308页):

拦截器方法必须始终调用InvocationContext.proceed(),否则不会调用后续的拦截器方法、bean业务方法或生命周期回调方法。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接