wxpay-sdk 接入微信支付sdk0.0.3,前端第二次调用之后支付验证签名失败详解程序员

报错,明显你的签名有问题,现在分析签名如何生成
在这里插入图片描述
微信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

(0)
上一篇 2021年7月15日
下一篇 2021年7月15日

相关推荐

发表回复

登录后才能评论