我有一个我无法理解的错误。 我正在实现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获得所有帮助。