报错,明显你的签名有问题,现在分析签名如何生成
微信H5内置对象唤起方式:
function onBridgeReady(){
WeixinJSBridge.invoke(
‘getBrandWCPayRequest’, {
“appId”:“wx2421b1c4370ec43b”, //微信公众号APPID
“timeStamp”:“1395712654”, //时间戳,自1970年以来的秒数
“nonceStr”:“e61463f8efa94090b1f366cccfbbb444”, //随机串
“package”:“prepay_id=u802345jgfjsdfgsdg888”, // 统一支付返回来的 prepay_id
“signType”:“MD5”, //微信签名方式
“paySign”:“70EA570631E4BB79628FBCA90534C63FF7FADD89” //微信签名
},
function(res){
if(res.err_msg == “get_brand_wcpay_request:ok” ){
// 使用以上方式判断前端返回,微信团队郑重提示:
//res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。
}
});
}
支付需要的六个参数appId,timeStamp,nonceStr,package,signType,paySign
其中timeStamp,nonceStr,paySign需要自己生成(注意:不能使用统一支付返回回来的nonceStr和paySign)
生成方式如下
java后台生成参数:
String timeStamp = String.valueOf(System.currentTimeMillis() / 1000L);
String packAge = “prepay_id=”+ response.getPrepayId();//会话标识prepay_id由统一支付返回
String nonceStr = RandomUtil.getRandomStr();
Map<String, String> map = new HashMap();
map.put(“appId”, APPID);//微信公众号APPID
map.put(“timeStamp”, timeStamp);
map.put(“nonceStr”, nonceStr);
map.put(“package”, packAge);
map.put(“signType”, “MD5”);
重点paySign生成方式
PayUtils.sign(map, mchKey) //mchKey 是微信支付32位秘钥
public static String sign(Map<String, String> params, String signKey) {
SortedMap<String, String> sortedMap = new TreeMap(params);
StringBuilder toSign = new StringBuilder();
Iterator var4 = sortedMap.keySet().iterator();
while(var4.hasNext()) {
String key = (String)var4.next();
String value = (String)params.get(key);
if (StringUtils.isNotEmpty(value) && !"sign".equals(key) && !"key".equals(key)) {
toSign.append(key).append("=").append(value).append("&");
}
}
toSign.append("key=").append(signKey);
return DigestUtils.md5Hex(toSign.toString()).toUpperCase();
}
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/1743.html