- EJB教程
- EJB - 主页
- EJB - 概述
- EJB - 环境设置
- EJB - 创建应用程序
- EJB-无状态Bean
- EJB - 有状态 Bean
- EJB-持久性
- EJB - 消息驱动 Bean
- EJB - 注释
- EJB-回调
- EJB-定时器服务
- EJB - 依赖注入
- EJB-拦截器
- EJB - 可嵌入对象
- EJB - Blob/Clob
- EJB - 事务
- EJB-安全性
- EJB - JNDI 绑定
- EJB - 实体关系
- EJB - 访问数据库
- EJB - 查询语言
- EJB - 异常处理
- EJB-Web 服务
- EJB - 打包应用程序
- EJB 有用资源
- EJB - 快速指南
- EJB - 有用的资源
- EJB - 讨论
EJB - 异常处理
EJB 是通常基于分布式环境的企业应用程序的一部分。因此,除了可能发生的正常异常之外,还可能存在通信故障、安全权限、服务器停机等异常。
EJB 容器以两种方式考虑异常 -
应用程序异常- 如果违反业务规则或执行业务逻辑时发生异常。
系统异常- 不是由业务逻辑或业务代码引起的任何异常。RuntimeException、RemoteException 都是SystemException。例如,EJB 查找期间出错。RuntimeException、RemoteException 都是SystemException。
EJB容器如何处理异常?
当应用程序异常发生时,EJB容器拦截异常,但将异常返回给客户端。除非在代码中通过 EJBContext.setRollBackOnly() 方法指定,否则它不会回滚事务。如果发生应用程序异常,EJB 容器不会包装异常。
当系统异常发生时,EJB容器拦截异常,回滚事务并启动清理任务。它将异常包装到 RemoteException 中并将其抛出给客户端。
处理应用程序异常
应用程序异常通常在会话 EJB 方法中引发,因为这些方法负责执行业务逻辑。应用程序异常应在业务方法的 throws 子句中声明,并在业务逻辑失败时抛出。
@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
...
public List<Book> getBooks() throws NoBookAvailableException {
List<Book> books =
entityManager.createQuery("From Books").getResultList();
if(books.size == 0)
throw NoBookAvailableException
("No Book available in library.");
return books;
}
...
}
处理系统异常
系统异常随时可能发生,例如命名查找失败、获取数据时发生sql错误等。在这种情况下,此类异常应该包装在 EJBException 下并抛出回客户端。
@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
...
public List<Book> getBooks() {
try {
List<Book> books =
entityManager.createQuery("From Books").getResultList();
} catch (CreateException ce) {
throw (EJBException) new EJBException(ce).initCause(ce);
} catch (SqlException se) {
throw (EJBException) new EJBException(se).initCause(se);
}
return books;
}
...
}
在客户端,处理 EJBException。
public class EJBTester {
private void testEntityEjb() {
...
try{
LibraryPersistentBeanRemote libraryBean =
LibraryPersistentBeanRemote)ctx.lookup("LibraryPersistentBean/remote");
List<Book> booksList = libraryBean.getBooks();
} catch(EJBException e) {
Exception ne = (Exception) e.getCause();
if(ne.getClass().getName().equals("SqlException")) {
System.out.println("Database error: "+ e.getMessage());
}
}
...
}
}