当支付宝回调接口失败时,需要系统化的处理策略来确保交易状态一致性和良好的用户体验。以下是完整的处理方案:
一、失败原因分析
常见失败原因
- 网络问题:超时、连接中断
- 验签失败:签名算法不一致或参数被篡改
- 参数错误:缺少必要参数或格式不正确
- 商户系统问题:接口异常、数据库故障
- 重复通知:支付宝重试机制导致的重复回调
二、实时处理策略
1. 基础校验与响应
@PostMapping("/alipay/notify")
public String handleNotify(HttpServletRequest request) {
try {
// 1. 参数转换
Map<String, String> params = convertRequestToMap(request);
// 2. 验签(必须)
boolean signVerified = AlipaySignature.rsaCheckV1(params, ALIPAY_PUBLIC_KEY, "UTF-8", "RSA2");
if (!signVerified) {
log.error("支付宝回调验签失败:{}", params);
return "failure"; // 告诉支付宝处理失败,会重试
}
// 3. 处理业务逻辑
processPayment(params);
return "success"; // 必须返回success告诉支付宝已处理
} catch (Exception e)