支付宝支付0.04元时,本地开发测试通过,但是线上接口报错:[参数无效:订单总金额格式错误]

2023-10-16 19:20:02 浏览数 (1)

背景

今天测试支付宝扫码支付时,出现了这个问题

首先,我们的业务场景是售卖机,Android端,通关选取商品后,下单点击支付方式,选择支付宝 此时,无法显示支付二维码 描述如下:

代码语言:javascript复制
通过线上报错信息发现,提示错误:ACQ.INVALID_PARAMETER,其实就是 “非法的订单总金额格式”
而且,
注意到:当金额为 0.03、0.04 时才报错,0.01、0.02、0.05 元都正正常运行
但是,
本地测试时,无法复现线上情况,
于是进行支付金额的打印、比对,排查问题所在 ...

分析、解决

  • 首先,定位到问题所在:支付金额的格式不符合支付宝规范 其次,出现开发环境与线上环境场景差别问题:基本认为是 Window10Linux 的系统差异
  • 如下为,我调用支付二维码显示时的,接口反馈
代码语言:javascript复制
float(0.04) //支付金额

object(stdClass)#173 (2) {
  ["alipay_trade_precreate_response"]=>
  object(stdClass)#172 (4) {
    ["msg"]=>
    string(15) "Business Failed"
    ["code"]=>
    string(5) "40004"
    ["sub_msg"]=>
    string(42) "参数无效:订单总金额格式错误"
    ["sub_code"]=>
    string(21) "ACQ.INVALID_PARAMETER"
  }
  ["sign"]=>
  string(344) "WMtAqprkfNUnS9zXiSRdenpsZ7sHjgV1SUcejTSWNDQ/GGYZCTqJDW3QCxARJna0L1IMpNCaCiK4 8cJt7mgHJ1HJEKCR8B9qKylQqG7s4vZD SJpgYxDZTkdYUW9m4OxbOvJn599LCdliDkz0VLIiXHO54jOxULgsa3GtHqup6xkiDsT5zBQafFm9XRofoOoyXBlkNGfDo80t2rdab6O4ligMZlPeGQYxLfG08RUTzvKgIuacunwdxT06yFPqr53l/3IolVGSRi4byGPSXpNOcHrjjuNmG DQFrM8/sy0R9lw296fRC43Y/8qDFwYiuqLkI5kmmYB89Ka/GfzUrkg=="
}
  • 搜索网上经验,只有如下链接 :ACQ.INVALID_PARAMETER(参数无效:非法的订单总金额格式) 测试发现,如果传值是 0.010.02 就没问题、0.030.04 就无法通过
  • 解决方案: 推测,使用的 floatval() 强制转化存在误差、于是使用了 sprintf() 强制两位小数形式转化 幸运的是,再次测试,完美解决. 希望能帮到有需要的道友 …
代码语言:javascript复制
 //订单总价
 $orderTotal = floatval(array_sum(array_column($cartList, 'total')));
 $orderTotal = sprintf("%.2f",$orderTotal);

0 人点赞