10

由于 JPA 2.0 不支持注入 EntityListener(JPA 2.1 将),决定使用 JNDI 查找来获取BeanManager并通过它获取登录用户。我定义了一个EntityListener类似的:

public class MyEntityListener {

    public static BeanManager getBeanManager() {
        try {
            InitialContext initialContext = new InitialContext();
            return (BeanManager) initialContext.lookup("java:comp/BeanManager");
        } catch (NamingException e) {
            e.printStackTrace();
            return null;
        }
    }

    public Object getBeanByName(String name) {
        BeanManager bm = getBeanManager();
        Bean bean = bm.getBeans(name).iterator().next();
        CreationalContext ctx = bm.createCreationalContext(bean);
        return bm.getReference(bean, bean.getClass(), ctx);
    }

    @PrePersist
    @PreUpdate
    public void onPreInsertOrUpdate(MyEntity entity) {
        User loggedInUser = (User) getBeanByName("loggedInUser");
        entity.setUpdatedUser(loggedInUser);
        entity.setUpdatedTimestamp(new Date());
    }
}

用户在会话范围内被管理为:

@SessionScoped
public class UserManager implements Serializable {

    private User loggedInUser;

    @Produces
    @Named("loggedInUser")
    public User getLoggedInUser() {
        return loggedInUser;
    }

    // Set the logged in user after successfully login action
}

我想知道这种方法有什么缺点或需要注意的地方。性能吞吐量?当有多个登录用户在他们自己的范围内同时更新实体时会发生什么?
休眠 JPA 2.0
缝焊 CDI
Glassfish 3.1.2

4

1 回答 1

4

你的方法是正确的。

性能吞吐量?

恕我直言,无需担心 - JPA 2.1 将使用等效机制。但是为了安全起见,一定要写一个真实的测试。

当有多个登录用户在他们自己的范围内同时更新实体时会发生什么?

所有(非依赖范围的)bean 引用都在内部代理。底层 CDI 实现必须保证正确的分辨率。

于 2012-05-26T12:53:55.003 回答