背景
今天测试支付宝扫码支付时,出现了这个问题
首先,我们的业务场景是售卖机,Android端,通关选取商品后,下单点击支付方式,选择支付宝 此时,无法显示支付二维码 描述如下:
代码语言:javascript复制通过线上报错信息发现,提示错误:ACQ.INVALID_PARAMETER,其实就是 “非法的订单总金额格式”
而且,
注意到:当金额为 0.03、0.04 时才报错,0.01、0.02、0.05 元都正正常运行
但是,
本地测试时,无法复现线上情况,
于是进行支付金额的打印、比对,排查问题所在 ...
分析、解决
- 首先,定位到问题所在:支付金额的格式不符合支付宝规范
其次,出现开发环境与线上环境场景差别问题:基本认为是
Window10
与Linux
的系统差异 - 如下为,我调用支付二维码显示时的,接口反馈
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.01
、0.02
就没问题、0.03
、0.04
就无法通过 - 解决方案:
推测,使用的
floatval()
强制转化存在误差、于是使用了sprintf()
强制两位小数形式转化 幸运的是,再次测试,完美解决. 希望能帮到有需要的道友 …
//订单总价
$orderTotal = floatval(array_sum(array_column($cartList, 'total')));
$orderTotal = sprintf("%.2f",$orderTotal);