背景
-
今天测试支付宝扫码支付时,出现了这个问题
首先,我们的业务场景是售卖机,Android端,通关选取商品后,下单点击支付方式,选择支付宝
此时,无法显示支付二维码
描述如下:通过线上报错信息发现,提示错误: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);