项目场景:
` 在通过微信小程序和stm32wb55进行蓝牙交互,由小程序根据业务逻辑调起微信支付V3服务商版,支付完成后,由服务商发起分账,后台没有搭建独立的服务器,而是通过微信云开发,在云函数里实现支付,单号查询,分账功能
问题描述
`在调起支付后,发现,从调起到出现微信支付界面,竟然需要4~5秒的时间.这个时间是 不可接受的.
原因分析:
接口参数的签名算法比较复杂,因为手机的算力有限,导致整个支付拉起的时间过长,
let nonceStr = that.getNonceStr()
let timeStamp = parseInt(Date.now() / 1000)
let paySign =sp_appid + “\n” + timeStamp + “\n” + nonceStr + “\n” + ‘prepay_id=’+ res.result.prepay_id + “\n”
console.log(‘paySign=’,paySign)
console.log(‘res’, res)
var sign_rsa = new RSA.RSAKey();
sign_rsa = RSA.KEYUTIL.getKey(privatekeyStr);
console.log(‘签名RSA:’)
console.log(sign_rsa)
var hashAlg = ‘sha256’;
hSig = sign_rsa.signString(paySign, hashAlg);
hSig = RSA.hex2b64(hSig); // hex 转 b64
console.log(“签名结果:” + hSig)
解决方案:
因为云函数是运行在高性能的服务器端,有强大的算力,把整个支付过程中的签名都放到云函数里执行,就解决这个4~5秒的长延时问题.但是这样又带来另外一个问题就是增加了云函数的开销,有可能会导致云函数使用费用的增加.