Java Web 项目(Spring 项目)异常处理问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
hujianxin
V2EX    程序员

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

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

    求教大佬,在一般的工程里,我们习惯定义 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     Solana     1168 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 23:39 PVG 07:39 LAX 15:39 JFK 18:39
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86