首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

java web项目整体错误处理机制

2012-08-22 
java web项目整体异常处理机制在实际的j2ee项目中,系统内部难免会出现一些异常,如果把异常放任不管直接打

java web项目整体异常处理机制

在实际的j2ee项目中,系统内部难免会出现一些异常,如果把异常放任不管直接打印到浏览器可能会让用户感觉莫名其妙,也有可能让某些用户找到破解系统的方法。

出来工作一年时间了,我也大概对异常处理有了一些了解,在这呢小弟简单介绍下个人对异常处理的见解,抛砖引玉,希望各位大神提出宝贵的意见和建议。

?

就拿spring+struts2+hibernate项目说明:通常一个页面请求到后台以后,首先是到action(也就是所谓mvc的controller),在action层会调用业务逻辑service,servce层会调用持久层dao获取数据。最后执行结果会汇总到action,然后通过action控制转发到指定页面,执行流程如下图所示:


java web项目整体错误处理机制
?

而这三层其实都有可能发生异常,比如dao层可能会有SQLException,service可能会有NullPointException,action可能会有IOException,一但发生异常并且程序员未做处理,那么该层不会再往下执行,而是向调用自己的方法抛出异常,如果dao、service、action层都未处理异常的话,异常信息会抛到服务器,然后服务器会把异常直接打印到页面,结果就会如下图所示:


java web项目整体错误处理机制
?

?

其实这种错误对于客户来说毫无意义,因为他们通常是看不懂这是什么意思的。

刚学java的时候,我们处理异常通常两种方法:①直接throws,放任不管;②写try...catch,在catch块中不作任何操作,或者仅仅printStackTrace()把异常打印到控制台。第一种方法最后就造就了上图的结果;而第二种方法更杯具:页面不报错,但是也不执行用户的请求,简单的说,其实这就是bug(委婉点:通常是这样)!

?

那么发生异常到底应该怎么办呢?我想在大家对java异常有一定了解以后,会知道:异常应该在action控制转发之前尽量处理,同时记录log日志,然后在页面以友好的错误提示告诉用户出错了。大家看下面的代码:


?

?

然后我们回到刚才处理异常的地方,如果大家积累了一些项目经验以后会发现使用上面那种处理异常的方式可能还不够灵活:

①因为spring把大多数非运行时异常都转换成运行时异常(RuntimeException)最后导致程序员根本不知道什么地方应该进行try...catch操作

②每个方法都重复写try...catch,而且catch块内的代码都很相似,这明显做了很多重复工作而且还很容易出错,同时也加大了单元测试的用例数(项目经理通常喜欢根据代码行来估算UT case)

③发生异常有很多种情况:可能有数据库增删改查错误,可能是文件读写错误,等等。用户觉得每次发生异常都是“访问过程中产生错误,请重试”的提示完全不能说明错误情况,他们希望让异常信息更详尽些,比如:在执行数据删除时发生错误,这样他们可以更准确地给维护人员提供bug信息。

?

如何解决上面的问题呢?我是这样做的:JDK异常或自定义异常+异常拦截器

struts2拦截器的作用在网上有很多资料,在此不再赘述,我的异常拦截器原理如下图所示:


java web项目整体错误处理机制
?首先我的action类、service类和dao类如果有必要捕获异常,我都会try...catch,catch块内不记录log,通常是抛出一个新异常,并且注明错误信息:

?

上面这是一个很简单的异常拦截器,大家可以使用自定义异常,那样会更灵活一些。

?

以上异常拦截器可以使用其它很多技术替换:比如spring aop,servlet filter等,根据项目实际情况处理。

?

【补充】ajax也可以进行拦截,但是因为ajax属于异步操作,action通过response形式直接把数据返回给ajax回调函数,如果发生异常,ajax是不会执行页面跳转的,所以必须把错误信息返回给回调函数,我针对json数据的ajax是这样做的:

 


如果是ajax请求,提示处理:
    12 楼    pml346680914    2011-06-10              楼主说说简单的jsp+javabean架构如何处理异常??    13 楼    lucky16    2011-06-11              首先感谢楼主的分享,这个问题我曾经也思考了一下,但是始终没有找到觉得完美的方法!    14 楼    itlangqun    2011-06-11              楼主可否发个简单示例,我们进行扩充与自定义。    15 楼    jwx0925    2011-06-11              pml346680914 写道楼主说说简单的jsp+javabean架构如何处理异常??

可以用Servlet的filter吧~封装一个拦截器 16 楼 白糖_ 2011-06-11   itlangqun 写道楼主可否发个简单示例,我们进行扩充与自定义。

我的这篇文章有源码:
http://www.iteye.com/topic/1069749 17 楼 mib168 2011-06-13   一般都是service记录异常网上抛,struts来跳转 不错 回头整理 18 楼 zk7019311 2011-06-13   学到了不少东西啊 19 楼 freesky_zh 2011-10-03   总结得不错。 20 楼 hwh0919 2011-10-11   仁兄,我做项目过程中后台验证出错,用异常的方式抛出,这样会不会影响系统的性能呢?

热点排行