J2EE应用程序异常处理框架

1.    checked unchecked exceptions

l        致命错误、不可恢复错误、第三方包错误应包装为unchecked exception

l        业务逻辑异常流、安全异常包装为checked exception

l        J2ee应用中有Business exceptionDB exceptionsecurity exception confirmation exception等。

 

2.    抛出异常的策略

2.1 采用J2EE应用程序的前端控制器(front controller) 集中控制处理。这样开发者在实现具体的业务逻辑的时候就可以不关心异常的捕捉。

2.2 方法签名中throws 一个基类的异常。这样前端控制器中只要捕捉这个基类的异常,开发者可以定义自己派生的异常具体类

 

3.    web层处理unchecked exceptions

所有的unchecked exceptions 都应该在web层进行处理, 可以在web.xml中配置异常发生时显示定制的错误页面。

 

4. 封装第三方包的所有异常(Exception)为一个我们定义的unchecked exception

 

5. 对来自数据库操作的checked exception, 比如Employee not found, Order not found可以抽象一个RecordNotFoundException。至于这个RecordNotFoundException是因为Employee还是Order引起的作为context, context一起组成error code,抛给前端控制器。

 

6. 前端控制器中的错误处理

基类的异常处理(应用模板方法设计模式 Template Method)和子类(实现业务)。

部分代码如下,以struts为例:

public abstract class BaseAppDispatchAction extends DispatchAction {

     // ...

     protected static ThreadLocal expDisplayDetails = new ThreadLocal();

 

     public ActionForward execute(ActionMapping mapping, ActionForm form,

              HttpServletRequest request, HttpServletResponse response)

              throws Exception {

         // ...

         try {

              String actionMethod = request.getParameter(mapping.getParameter());

              return dispatchMethod(mapping, form, request, response,actionMethod);

         } catch (BaseAppException Ex) {

              ExceptionDisplayDTO expDTO = (ExceptionDisplayDTO) expDisplayDetails.get();

              IExceptionHandler expHandler = ExceptionHandlerFactory.getInstance().create();

              ExceptionDTO exDto = expHandler.handleException(expDTO.getContext(), userId, Ex);

              ActionErrors errors = new ActionErrors();

              errors.add(ActionErrors.GLOBAL_ERROR, new ActionError(exDto.getMessageCode()));

              this.saveErrors(request, errors);

              return mapping.findForward(expDTO.getActionForwardName());

         } catch (Throwable ex) {

              // log the throwable

              // throw ex;

         } finally {

              expDisplayDetails.set(null);

         }

     }

}

 

业务子类中代码如下:

//...

String exceptionActionForward = "SearchAdjustmentPage";

String exceptionContext = "divisionAction.searchDivision";

 

ExceptionDisplayDTO expDTO =

new ExceptionDisplayDTO(expActionForward, exceptionContext);

expDisplayDetails.set(expDTO);

//...

DivisionDTO divisionDTO =divisionBusinessDelegate.getDivisionByNum(fromDivisionNum);

//...

 

ExceptionDisplayDTO 作为data transfer object放在ThreadLocal中专门为了父类的异常处理用

 

7. Exception Handler

上面的集中异常控制是在Excepiton Handler中处理的,包括:

根据异常类型获取异常代码,异常代码会用来显示异常信息. 异常类型与异常代码的对应关系可以放到一个XML文件中. 根据异常代码取异常信息可以由ResouceBundle来实现,这样同时解决了异常信息国际化的问题. 两个异常配置的xml文件如下:

messagecode.employeeconfirmation

true

nologging

 

messagecode.recordnotfound

false

true

error

第二个异常文件考虑了我们上面讲的context问题. 如果抛出的异常是

RecordNotFoundException, 并且当前的contextorder.getOrder , 那么error code就是:messagecode.recordnotfound.order.getOrder

为了避免多次解析这个XML文件,可以实现一个ExceptionInfoCache ,启动应用时缓冲这个xml的内容,在ExceptionHandlerhandleException方法代码片断如下:

public ExceptionDTO handleException(String userId, BaseAppException exp) {

     ExceptionDTO exDTO = new ExceptionDTO();

     ExceptionInfoCache ecache = ExceptionInfoCache.getInstance();

     ExceptionInfo exInfo = ecache.getExceptionInfo(ExceptionHelper.getClassName(exp));

     String loggingType = null;

     if (exInfo != null) {

         loggingType = exInfo.getLoggingType();

         exDTO.setConfirmation(exInfo.isConfirmation());

         exDTO.setMessageCode(exInfo.getMessageCode());

     }

     FileLogger logger = new FileLoggerFactory().create();

     logger.logException(exp, loggingType);

}

 

 

 

 SEE: http://blog.csdn.net/szc5566/archive/2009/02/05/3864790.aspx

 

 

FROM: http://www.onjava.com/pub/a/onjava/2006/01/11/exception-handling-framework-for-j2ee.html

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值