• 请不要在回答技术问题时复制粘贴 AI 生成的内容
hujianxin
V2EX  ›  程序员

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

  •  
  •   hujianxin · Dec 26, 2017 · 5098 views
    This topic created in 3063 days ago, the information mentioned may be changed or developed.

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

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

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

    谢谢!

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

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

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

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

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

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

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

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

    想通了这些,就自然知道在哪里处理异常了。请同时参考以上各楼层的回答。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   888 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 51ms · UTC 20:52 · PVG 04:52 · LAX 13:52 · JFK 16:52
    ♥ Do have faith in what you're doing.