不同类型接口的异常处理规范

  1. 对于公司外的 http/api 开放接口必须使用 errorCode;
  2. 跨应用间 RPC 调用优先考虑使用 Result 方式,封装 isSuccess()方法、errorCode、errorMessage;
  3. 而应用内部推荐直接抛出异常即可。

说明:关于 RPC 方法返回方式使用 Result 方式的理由:

  1. 使用抛异常返回方式,调用方如果没有捕获到就会产生运行时错误。
  2. 如果不加栈信息,只是 new 自定义异常,加入自己的理解的 error message,对于调用端解决问题的帮助不会太多。如果加了栈信息,在频繁调用出错的情况下,数据序列化和传输的性能损耗也是问题。

备注:

1、http/api:

2、Result :

{
    "code": "0",
    "message": "successfully",
    "data": {
        "incomeStatistics": {
            "totalMoney": 0.0,
            "yesterdayMoney": 0.0,
            "monthMoney": 0.0,
            "todayMoney": 0.0,
            "weekMoney": 0.0
        },
        "balanceStatistics": {
            "trustSpecialAccountBalance": 0.0,
            "trustAccountBalance": 0.0,
            "loanBalance": 0.0
        },
        "applicationsStatistics": {
            "monthApplayNum": 0.0,
            "totalApplayNum": 0.0,
            "todayApplayNum": 0.0,
            "weekApplayNum": 0.0,
            "yesterdayApplayNum": 0.0
        },
        "generalStatistics": {
            "refundTotalNum": 0.0,
            "totalApplaySuccessRate": 0.0,
            "settleTotalNum": 0.0
        },
        "applicationSuccessStatistics": {
            "yesterdayApplicationSuccessNum": 0.0,
            "weekApplicationSuccessNum": 0.0,
            "monthApplicationSuccessNum": 0.0,
            "totalApplicationSuccessNum": 0.0,
            "todayApplicationSuccessNum": 0.0
        },
        "subsidyStatistics": {
            "subsidyNum": 0.0,
            "subsidyMoney": 0.0,
            "subsidyRate": 0.0
        }
    },
    "seqNo": "e1439b6f-7100-4a06-b01d-54a2355e31b7"
}

总结一句话:要有友好的异常信息提示

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值