应按调用阶段(请求构建、网络传输、响应解析)和可恢复性分类处理外部接口异常:请求构建错抛IllegalArgumentException,网络超时等可重试并熔断,响应解析错需按HTTP状态码语义处理。
处理外部接口调用时的异常,不能一概而用 try-catch(Exception e),关键在于按**发生阶段**和**可恢复性**分类,再匹配语义明确的标准异常或自定义异常类型。分类不清,容易掩盖真实问题,也难以做针对性重试、降级或告警。
Java调用外部API通常经历三个阶段:请求构建 → 网络传输 → 响应解析。每个阶段失败原因不同,应使用不同策略应对:
IllegalArgumentException 或自定义 InvalidRequestException,不重试,需修复代码。ConnectTimeoutException、SocketTimeoutException、UnknownHostException、SSLHandshakeException。它们反映基础设施或环境问题,具备临时性,适合加入指数退避重试;若连续失败,应触发熔断并告警。JsonParseException、ClassCastException、空指针(因字段缺失未判空)。其中业务状态码需根据语义处理(401 刷新 token,404 记录缺失,500 触发降级);解析类异常建议包装为 ApiResponseParseException 并附带原始响应体,便于排查。HTTP 状态码是重要信号,不应统一当作网络失败处理:
IllegalArgumentException;401/403 需单独捕获,走认证刷新流程;404 可记录日志后返回默认值或空结果,避免中断主流程。不要吞掉原始异常信息。推荐做法:
立即学习“Java免费学习笔记(深入)”;
new BusinessException("调用支付接口失败", e) 包装;InsufficientBalanceException),而非复用 RuntimeException;不是所有异常都适合重试:
ConnectTimeoutException 和 SocketTimeoutException 设为触发熔断的“失败异常”,而把 IllegalArgumentException 排除在外。