错误处理

一般情况下,DAO,Manager,Action类不对Exception做catch处理,产生的异常将抛出到Action层,通过ImsExceptionInterceptor这个webwork 拦截器将Exception包装成ActionError,并打印报告生成日志文件并交给ActionSupport.doInput方法执行。
如果该拦截器所列举的异常不符合Exception异常类型,则然后交给AjaxResultInterceptor(如果是AJAX请求)或webwork自带的
ExceptionMappingInterceptor处理一般跳转到统一的error.jsp页面,将错误信息进行展示。拦截器捕获到异常后对异常信息进行了补充,增加了httpRequest、http Session, Cookie, 当前用户等信息。
同时这些异常信息也写入到err文件中,文件路径在application.properties中的errorreport.path进行配置,err文件按日期存放,文件名为一串随机唯一字符,当页面中显示错误时,会有一个错误编号 : 比如20100903-be25b8c,20100903是日期,be25b8c是文件名,根据这两个信息就可以找到err文件。

系统按用途将日志划分为三种不同类型
13.1.2.1 messages.log
该日志主要记录开发阶段所有调试信息,按文件阀值生成新文件
13.1.2.2 hibernate.log
该日志记录Hibernate修改信息(包括字段信息,对HQL无效),按天生成文件hibernate.log.yyyy-MM-dd
13.1.2.3 xxx.err
该日志主要记录web层抛出的错误信息,按天生成名为yyyyMMdd文件夹,在改文件夹下,存放着当天的错误文件XXX.err,每次错误会产生一个唯一编码的err文件
系统运行期日志记录在工程下的logs/messages.log
JDBC运行时修改信息记录在logs/hibernate.log.yyyy-MM-dd

你可能感兴趣的:(错误)