EJB EntityManager导致NullPointerException

时间:2013-06-30 20:41:54

标签: nullpointerexception ejb entitymanager persist

我有一个我无法理解的错误。 我正在实现RSS处理应用程序。逻辑是用户获取某些RSS提要的链接并添加到数据库。如果Feed已存在于数据库中,则它将获取feed的id并将其添加到用户的订阅中。 这是代码:

 if (existfeed == null) {
            feed = loadFeed(url, syndfeed);
            em.persist(feed);
            if (feed.getFeedId() == null) {
                return "Persist of feed failed";
            } 
                uf.setFeedId(feed);
                uf.setUserId(user_id);
                try {
                    em.persist(uf);
                    loadFeedItems(syndfeed, feed);
                    //boolean ufadded = uf.addUserFeed(em);
                } catch (NoResultException ex) {
                    return "Persist of userfeed failed";
                } catch (PersistenceException ex) {
                    return "Persist of userfeed failed, em";
                }
                //boolean ufadded = uf.addUserFeed(em);

                //return true;                
            return "Feed added";
        } else {
            dbFeed = getFeed(feed.getLink());
            if(dbFeed==null)
                return "Faile to get feed from database";
            //http://appleinsider.ru/feed
            uf.setFeedId(dbFeed);
            uf.setUserId(user_id);
            try {
                em.persist(uf);
            } catch (PersistenceException ex) {
                //System.out.println(ex.getMessage());
                return "Unable to persist userfeed";
            }
            return "Feed added, existing";
        }

但是,如果用户添加了Feed,则其他用户无法添加,并且出现错误:

 Caused by: java.lang.NullPointerException
at ejb.FeedBean.addNewFeed(FeedBean.java:203) [Group_7_Impl_uwx09sua-ejb.jar:]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) [classes.jar:1.6.0_51]
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) [classes.jar:1.6.0_51]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) [classes.jar:1.6.0_51]
at java.lang.reflect.Method.invoke(Method.java:597) [classes.jar:1.6.0_51]
at org.jboss.as.ee.component.ManagedReferenceMethodInterceptorFactory

我只是不明白为什么会失败。 我的一个观点是,EntityManager可能不知何故为空。但是,在if语句的第一部分它起作用。

更新:我试图使用EntityManager查找方法,它导致同样的错误。所以,肯定的是,在if语句的第二部分,EntityManager在某种程度上是空的。

Thanx获得所有帮助。

0 个答案:

没有答案