我正在使用Glassfish 4部署一个应用程序。它过去有一个EJB,其中SessionContext是通过@Resource注释注入的。
@Stateless
@DeclareRoles({"StandardRole1", "StandardRole2"})
public class MyClass implements MyInterface {
@Resource
private SessionContext ctx;
@Override
public String getPrincipalName() {
return ctx.getPrincipal().getName();
}
}这件事做得很好。现在,我需要获得额外允许的角色来扩展应用程序。新角色并不总是相同的,因此向MyClass bean添加角色是没有选择的。我想出的是:
@Stateless
@DeclareRoles({"StandardRole1", "StandardRole2"})
public class NormalRoles implements RolesInterface {
@Resource
private SessionContext ctx;
@Override
public String getPrincipalName() {
return ctx.getPrincipal().getName();
}
}
@Decorator
@DeclareRoles({"NewRole1", "NewRole2"})
public abstract NewRoles implements RolesInterface {
@Inject
@Delegate
@Default
private RolesInterface defaultBean;
@Resource
private SessionContext ctx;
@Override
public String getPrincipalName() {
return ctx.getPrincipal().getName();
}
}
@Stateless
public class MyClass implements MyInterface {
@Inject
private RolesInterface rolesBean;
@Override
public String getPrincipalName() {
return rolesBean.getPrincipalName();
}
}现在,当我尝试运行这个程序时,我从NullPointerException装饰器那里得到了return ctx.getPrincipal().getName();上的一个NewRoles。问题-> SessionContext没有被注射。
我以前在PersistenceContext上发布了here时也遇到过这个问题。我试着用这种方法来解决这个问题,所以我做了这样的事情:
public class Producers {
@Produces
@Resource
private SessionContext em;
}然后在装饰器中使用@Inject注释而不是@Resource。这也没用。
我是否可以在装饰师中使用@Resource,或者做类似的事情?
发布于 2015-02-26 09:46:25
SessionContext是一个链接到EJB的资源,而Decorator不是一个EJB,而是一个CDI,所以获得一个空SessionContext是正常的。您可以尝试通过Jndi获取您的SessionContext,如下所示:http://javahowto.blogspot.fr/2006/06/4-ways-to-get-ejbcontext-in-ejb-3.html
https://stackoverflow.com/questions/28714061
复制相似问题