V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hujianxin
V2EX  ›  程序员

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

  •  
  •   hujianxin · 2017-12-26 17:08:01 +08:00 · 4323 次点击
    这是一个创建于 2525 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

    谢谢!

    19 条回复    2017-12-27 17:10:37 +08:00
    fengyu
        1
    fengyu  
       2017-12-26 17:12:57 +08:00
    hujianxin
        2
    hujianxin  
    OP
       2017-12-26 17:14:42 +08:00
    @fengyu 谢谢,这就是统一异常处理器
    paragon
        3
    paragon  
       2017-12-26 17:17:26 +08:00
    @advice controller
    Guozi1989
        4
    Guozi1989  
       2017-12-26 17:59:46 +08:00
    controller 统一 try cache。
    Guozi1989
        5
    Guozi1989  
       2017-12-26 18:02:38 +08:00
    @Guozi1989 catch
    jimisun
        6
    jimisun  
       2017-12-26 18:04:08 +08:00 via Android
    spring 不是有全局全局异常处理机制吗?
    jimisun
        7
    jimisun  
       2017-12-26 18:04:32 +08:00 via Android
    更正 springmvc
    a3mao
        8
    a3mao  
       2017-12-26 18:09:37 +08:00   ❤️ 1
    ExceptionHandler 统一处理
    lusyoe
        9
    lusyoe  
       2017-12-26 19:18:13 +08:00 via iPhone
    @Around AOP 中 try-catch 所有 Controller 接口异常,service 异常往 Controller 抛
    loveCoding
        10
    loveCoding  
       2017-12-26 19:28:13 +08:00
    1.service 需要处理异常吗?
    不需要

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

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

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

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

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

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

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

    想通了这些,就自然知道在哪里处理异常了。请同时参考以上各楼层的回答。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   931 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 22:12 · PVG 06:12 · LAX 14:12 · JFK 17:12
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.