Java Web 项目(Spring 项目)异常处理问题

2017-12-26 17:08:01 +08:00
 hujianxin

求教大佬,在一般的工程里,我们习惯定义 entity,dao,service,controller 几个层。但是异常在哪里处理,我还是把握不太准。

在 dao 层中,没有业务逻辑,单纯的与数据库交互,没有异常处理相关的代码。

  1. service 需要处理异常吗?
  2. service 需要抛出异常吗?
  3. controller 需要处理异常吗?
  4. 统一异常处理器一般处理什么类型的异常呢?
  5. 自定义异常一般什么类型,在什么地方处理呢?

谢谢!

4395 次点击
所在节点    程序员
19 条回复
fengyu
2017-12-26 17:12:57 +08:00
hujianxin
2017-12-26 17:14:42 +08:00
@fengyu 谢谢,这就是统一异常处理器
paragon
2017-12-26 17:17:26 +08:00
@advice controller
Guozi1989
2017-12-26 17:59:46 +08:00
controller 统一 try cache。
Guozi1989
2017-12-26 18:02:38 +08:00
@Guozi1989 catch
jimisun
2017-12-26 18:04:08 +08:00
spring 不是有全局全局异常处理机制吗?
jimisun
2017-12-26 18:04:32 +08:00
更正 springmvc
a3mao
2017-12-26 18:09:37 +08:00
ExceptionHandler 统一处理
lusyoe
2017-12-26 19:18:13 +08:00
@Around AOP 中 try-catch 所有 Controller 接口异常,service 异常往 Controller 抛
loveCoding
2017-12-26 19:28:13 +08:00
1.service 需要处理异常吗?
不需要

2.service 需要抛出异常吗?
需要

3.controller 需要处理异常吗?
需要,统一在 ExceptionHandler 处理

4.统一异常处理器一般处理什么类型的异常呢?
所有异常都应该在此统一处理 , 按异常类型返回不同错误码

5.自定义异常一般什么类型,在什么地方处理呢?
比如 UsernameOrPasswordException,ParamException,在 ExceptionHandler 中处理
iyangyuan
2017-12-26 19:41:04 +08:00
这得看实际情况,没有一劳永逸的规则。
cjyang1128
2017-12-26 19:46:37 +08:00
统一异常处理器处理所有的异常啊。。
hujianxin
2017-12-26 21:16:00 +08:00
@loveCoding 感谢哈,大佬!
谢谢各位大佬,不一一 @了,大家的主流意见都是使用统一异常处理器来处理。
anmaz
2017-12-26 22:30:43 +08:00
struts 直接配全局过滤
nl101531
2017-12-26 22:39:03 +08:00
一个线程内的操作那么顶层处理,对于一个请求那么应该是 Controller 层处理,一般使用各种 MVC 框架的统一异常拦截机制.

也就是说或你的 service 应该对上抛.

那么问题来了,如果你的 service 又承担 RPC 调用,那么这就不是一个线程内的东西了,那么此时应该自己消耗掉异常,返回错误码之类的封装,那么一般的做法就是 service 层上再来一个 facade 层承担 rpc 调用的责任.

见识少,不知道是否还有其他更加优秀的做法.
yanjinbin
2017-12-27 01:11:25 +08:00
看看 httpservlet doservice 和 springdispathservlet dodispatch 就知道异常如何被处理了
yanjinbin
2017-12-27 01:12:01 +08:00
用 globalcontrolleradvice
hantsy
2017-12-27 12:31:57 +08:00
sorra
2017-12-27 17:10:37 +08:00
关键在于:
1. 记录 log (一般每个异常都要记 log,以备日后排查,这个可以统一处理)
2. 向用户报告错误 (怎样把异常信息翻译成适合用户了解的错误信息?这个问题值得思考)
3. 某种类型的异常需要如何处理?放任还是恢复?

想通了这些,就自然知道在哪里处理异常了。请同时参考以上各楼层的回答。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://tanronggui.xyz/t/417796

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX