給大家同步一下我這邊的方案构捡,2022年03月24日:
最終解決方案是:
讓后臺返回所有需要的字段塞颁,客戶端拿著數(shù)據(jù),直接請求服務器佛猛,即可吊起微信支付。
示例:
PayReq request = new PayReq();
// 應用ID (可本地寫死坠狡,也可服務器返回)
request.appId = PayConstants.WX_APP_ID;
// 商戶號 (可本地寫死继找,也可服務器返回)
request.partnerId = PayConstants.WX_APP_MICID;
// 預支付交易會話ID, 微信返回的支付交易會話ID
request.prepayId = mPayOrderBean.getPrepay_id();
// 擴展字段, 固定值:Sign=WXPay逃沿, (可本地寫死婴渡,也可服務器返回)
request.packageValue = "Sign=WXPay";
// 隨機字符串, 隨機生成 隨機字符串凯亮,不長于32位边臼。推薦隨機數(shù)生成算法,服務器生成 (最好是 32 位假消,如果是 低于 12 位柠并,可能有問題)
request.nonceStr = mPayOrderBean.getNonceStr();
// 時間戳,一定是服務器的時間戳 (最好是服務器的時間戳)
request.timeStamp = mPayOrderBean.getTimestamp();
// 簽名 (這個簽名是后端根據(jù)證書簽名的富拗,一定不要自己寫哦臼予,要不然調試好久都沒結果)
request.sign = mPayOrderBean.getSign();
// 這個字段可有可無。建議還是帶上媒峡。
request.extData = "app data";
mIWXAPI.sendReq(request);
簡單描述:
1 服務器使用下單接口后瘟栖,會返回 (以下是測試數(shù)據(jù)):
{
"return_code": "SUCCESS",
"return_msg": "OK",
"appid": "APPID",
"mch_id": "商戶號",
"nonce_str": "隨機字符串",
"sign": "081675D3A89B1A735613CF2D777E6F06",
"prepay_id": "wx201706052018103dd047b0880123350695",
"result_code": "FAIL",
"err_code": "ORDERPAID",
"err_code_des": "該訂單已支付"
}
2 其中比較關鍵是: sign。 這個返回客戶端也不行谅阿,需要服務器做二次加密半哟。
具體是:
"appid=" + appid + "&noncestr=" + nonce_str + "&package=Sign=WXPay" + "&partnerid=" + mch_id + "&prepayid=" + prepayid + "×tamp=" + timeStamp + "&key=" + key;
一定要注意:這里的key為商戶的key酬滤,而不是AppSecret;timestamp為當前的時間戳
3 最后返回的字段:
{
"appid": "第1步的APPID",
"mch_id": "第1步的mch_id",
"prepay_id": "第1步的prepay_id",
"nonce_str": "第1步的nonce_str",
"sign": "第3步的簽名寓涨,不是第1步的簽名",
"timestamp":"第3步的時間戳"
}
4 注意查看我上面的注釋盯串,錯一個,就會提示簽名失敗戒良。
參見:
https://juejin.cn/post/6844903832875433991 (比較細致)
https://blog.csdn.net/github_39118247/article/details/100198628 (比較老体捏,或者適合客戶端直接操作具體數(shù)據(jù))