java try 快捷键_java try catch 问题

Controller层中使用try catch功能

1 publicWrapper billQuery(@RequestBody OrderBillQueryReq orderBillQueryReq){2 log.info("账单列表查询入参:{}", JSON.toJSONString(orderBillQueryReq));3 try{4 PageList billList =orderBillService.list(orderBillQueryReq);5 return WrapMapper.ok(new PageVO<>(billList));6 } catch(Exception e) {7 log.error("查询账单列表失败,错误信息:{}", e.getMessage(),e);8 returnWrapMapper.error(e.getMessage());9 }10 }11 }

ServiceImpl层中是否使用try catch功能对Controller层的影响

1,使用try catch功能,抓Exception

1 public PageListlist(OrderBillQueryReq orderBillQueryReq) {2 try {

3 List listIN = new ArrayList<>();

4 listIN.get(2);

5 } catch (Exception e) {

6 log.error("错误信息:{}", e.getMessage(),e);

7 }8

9 //业务逻辑

10 return new PageList<>(listModel,pageList.getPaginator());11 }

结果:service层会打印错误日志,Controller层不打印错误信息和日志。但是下面的业务代码会继续执行,向前端输出正常结果。

1 [service-xx-bill] 2020-04-08 10:27:27.932 [http-nio-9100-exec-1] ERROR c.w.s.c.bill.service.impl.OrderBillServiceImpl - 错误信息:Index: 2, Size: 0

2 java.lang.IndexOutOfBoundsException: Index: 2, Size: 0

3 at java.util.ArrayList.rangeCheck(ArrayList.java:657)4 at java.util.ArrayList.get(ArrayList.java:433)5 at xxxxxxxl.OrderBillServiceImpl.list(OrderBillServiceImpl.java:56)6 at xxxxxxx.controller.OrderBillController.billQuery(OrderBillController.java:59)7 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

2,不使用try catch功能。

1 public PageListlist(OrderBillQueryReq orderBillQueryReq) {2 List listIN = new ArrayList<>();

3 listIN.get(2);4

5 //业务逻辑

6 return new PageList<>(listModel,pageList.getPaginator());7 }

结果:service层不打印错误日志,Controller层打印错误信息和日志。下面的业务代码不会继续执行,向前端输出错误信息。

1 [xxxx-bill] 2020-04-08 10:38:37.259 [http-nio-9100-exec-2] ERROR c.w.s.c.bill.controller.OrderBillController - 查询账单列表失败,错误信息:Index: 2, Size: 0

2 java.lang.IndexOutOfBoundsException: Index: 2, Size: 0

3 at java.util.ArrayList.rangeCheck(ArrayList.java:657)4 at java.util.ArrayList.get(ArrayList.java:433)5 at xxxx.bill.service.impl.OrderBillServiceImpl.list(OrderBillServiceImpl.java:55)6 at xxxx.bill.controller.OrderBillController.billQuery(OrderBillController.java:59)7 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

server层使用断言 AssertUtil.isTrue

在controller层使用 try catch,catch里抓取BizException,使用

WrapMapper.wrap(e.getCode(),e.getMessage());

获取错误码和错误信息。同样在controller层不使用 try catch,前端页面能拿到断言的错误信息和错误码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值