一般支付都是和第三方支付进行对接的,比如:支付宝、微信、中国银联。  第三方接口:下单接口,支付接口,退款接口,查询接口

支付状态包括支付成功,支付失败,退款成功,退款失败,       

1、支付流程:
  付款的唯一标识是付款编号;
  退款也会有退款编号
    1.1 正常支付流程:

    正常的发起一笔支付请求,检查点:
    1)用户发过去的信息有携带key值
    2)商户系统本地数据会留存一份用户的订单信息,并且会根据每笔订单信息生成一笔支付信息(同时留存到本地)
    3)第三方支付成功,第三方有存支付订单信息
    4)付款成功或失败,订单状态都会改变
  1.2 异常用例:
   用户                     1、修改用户发过去的数据:

    1)产品ID与价值不对等---->检查点:篡改数据和key,检查商户系统报错:key值不对或者是用户数据有误。
    2)取消支付
    3)重复发起支付请求

   商户和第三方       2、商户系统-第三方之间:

    1)密钥搞错-第三方报错,不接收密钥
    2)提交商户系统里面不存在的订单/支付订单->第三方这里也是不能通过请求
    3)篡改用户支付金额–>第三方也要检查

    用户和第三方  3、第三方–用户之间:
    1)支付密码错误/余额不足
    2)取消支付
    3)重复支付[对账—>处理退款]

2、退款流程

  2.1   正常用例

     用户发起退款—>该用户的订单以及支付订单号都要存在。—检查点:商户系统/第三方检查数据没有问题,可以退款成功—>交易状态改成退款

  2.2   异常用例
    1:无故发起退款:提交不存在的订单号或者支付订单号 —>订单号不存在/支付订单号不存在

    2:信息不匹配发起退款:提交订单号与支付订单号不匹配的数据—>订单号/支付订单号有误

    3:退款大于实际金额:提交的退款金额大于实际支付订单的金额–>商户系统要报错

    4:商户系统这里发过去的请求:退款金额大于实际支付金额–>第三方要报错

3、bug

    支付流程bug    第三方如果一直不返回(订单状态取决于支付返回状态)ps:与下边BUG描述重复
    支付的异常bug   第三方一直未返回支付状态,当时没有对这种场景做判断,程序报错
    解决办法       我们的后端加了一种支付中/退款的状态,当第三方一直不返回支付状态,这个订单的状态为支付中,显示在全部订单中     付款、退款、对账三种状态