官方文檔地址JSAPI
https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_7&index=6
官方文檔地址統(tǒng)一下單
https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_1
后臺獲取prepay_id參數(shù)地址
https://api.mch.weixin.qq.com/pay/unifiedorder
請求參數(shù)
String nonce_str= UUID.randomUUID().toString().replace("-", "");//隨機數(shù)
SortedMap<String, Object> packageParams = new TreeMap<String, Object>();
packageParams.put("appid", APPID);
packageParams.put("attach", attach);//附加數(shù)據(jù)
packageParams.put("body", describe);//商品描述
packageParams.put("mch_id", MCHID);//商戶號
packageParams.put("nonce_str", nonce_str);//隨機數(shù)
packageParams.put("notify_url", NOTIFY_URL);//異步通知地址
packageParams.put("out_trade_no", out_trade_no);//商戶訂單號
packageParams.put("spbill_create_ip", spbill_create_ip);//訂單生成的機器 IP
packageParams.put("total_fee", money);//總金額必須int
packageParams.put("trade_type", "JSAPI"); //類型為JSAPI
packageParams.put("openid", openid); //JSAPI 時必須傳遞用戶openid
String sign = WxPayUtils.createSign(packageParams,KEY);//商戶KEY萄窜, MD5簽名(以下簽名方式均按照官方要求矢门,并且要與JS端簽名類型一致)
xml拼接參數(shù)與packageParams一致
String xml="<xml>"+
"<appid>"+APPID+"</appid>"+
"<attach>"+attach+"</attach>"+
"<body><![CDATA["+describe+"]]></body>"+
"<mch_id>"+MCHID+"</mch_id>"+
"<nonce_str>"+nonce_str+"</nonce_str>"+
"<sign>"+sign+"</sign>"+
"<notify_url>"+NOTIFY_URL+"</notify_url>"+
"<out_trade_no>"+out_trade_no+"</out_trade_no>"+
"<spbill_create_ip>"+spbill_create_ip+"</spbill_create_ip>"+
"<total_fee>"+money+"</total_fee>"+
"<trade_type>JSAPI</trade_type>"+
"<openid>"+openid+"</openid>"+
"</xml>";
返回參數(shù)為xml格式數(shù)據(jù)
將返回的相應(yīng)字段get后回傳給JS前端
String appid = (String) map.get("appid");
String prepay_id = (String) map.get("prepay_id");
String nonce_str = (String) map.get("nonce_str");
SortedMap<String, Object> mapParam = new TreeMap();
mapParam.put("appId", appid);
mapParam.put("timeStamp", String.valueOf(cUtil.getTime()));
mapParam.put("nonceStr", nonce_str.trim());
mapParam.put("package", "prepay_id="+prepay_id.trim());
mapParam.put("signType", "MD5");
//二次簽名攘须,需要再次將參數(shù)(不包括paySign)MD5簽名
mapParam.put("paySign", WxPayUtils.createSign(mapParam,WxJSPay.KEY));
JS端示例(官方)
function onBridgeReady(){
WeixinJSBridge.invoke(
'getBrandWCPayRequest', {
"appId":"wx2421b1c4370ec43b", //公眾號名稱,由商戶傳入
"timeStamp":"1395712654", //時間戳圣贸,自1970年以來的秒數(shù)
"nonceStr":"e61463f8efa94090b1f366cccfbbb444", //隨機串
"package":"prepay_id=u802345jgfjsdfgsdg888",
"signType":"MD5", //微信簽名方式:
"paySign":"70EA570631E4BB79628FBCA90534C63FF7FADD89" //微信簽名
},
function(res){
if(res.err_msg == "get_brand_wcpay_request:ok" ){
// 使用以上方式判斷前端返回,微信團隊鄭重提示:
//res.err_msg將在用戶支付成功后返回ok挚歧,但并不保證它絕對可靠。
}
});
}
支付簽名校驗不通過
1:檢查返回給前端的nonceStr字段 是否與下單接口返回的一致
2:檢查paySign是否二次簽名吁峻,回傳給前端是否正確
3:檢查appid是否與前端一致
4:檢查signType是否一致
5:檢查nonceStr生成規(guī)則滑负,注意符號(例如:- )
下單失敗,超時
1:檢查timeStamp是否10位int
2:檢查prepay_id是否在有效期內(nèi)
該商戶沒有預(yù)訂單下單權(quán)限
檢查商戶公眾號后臺是否配置相關(guān)JSAPI
HttpUrl鏈接不在合法范圍內(nèi)
配置可外網(wǎng)訪問