微信支付total_fee 长度不正确

展开阅读全文

调用支付JSAPI缺少参数:total_fee, 跪求大神解答

02-26

Map<String,String> map = new HashMap<>(); String suijishu = WXPayUtil.generateNonceStr(); String dindanhao = GetRandom.getRandomStringByLength(32); System.out.println("订单号:"+dindanhao); map.put("appid",payhospital.getAppid());// appid map.put("mch_id",payhospital.getMchid());// 商户号 map.put("sign_type","MD5"); map.put("nonce_str",suijishu);// 随机字符串 map.put("body","ceshizhifu");// 商品名称 map.put("notify_url","http://wxzf.yiruan01.com/zuul/user/payhospitalbyid/result"); // 回调地址 map.put("out_trade_no",dindanhao);// 订单号 map.put("spbill_create_ip","47.95.245.237");// 终端ip(调用微信支付API的机器IP)//47.95.245.237 map.put("total_fee","1");// 订单金额 现在默认写死,money map.put("trade_type","JSAPI"); // 交易类型交易类型 map.put("openid",openid);// openid //生成签名 //将集合M内非空参数值的参数按照参数名ASCII码从小到大排序 String paixu = GroupWeuxin.formatUrlMap(map,false,false); // 拼接key String SignTemp = paixu+"&key="+payhospital.getKeyy(); // MD5加密 并且转换为大写 String sign = Md5Util.getMD5String(SignTemp).toUpperCase(); map.put("sign",sign); // 将map转换为xml String xml = WXPayUtil.mapToXml(map); // 判断签名是否正确 Boolean boo = WXPayUtil.isSignatureValid(xml,payhospital.getKeyy()); System.out.println("判断第一次签名是否正确:"+boo); String url = "https://api.mch.weixin.qq.com/pay/unifiedorder"; ResponseEntity<String> responseEntity = restTemplate.postForEntity(url,xml,String.class); String res1 = responseEntity.getBody(); // 获取返回参数到此后台完成 Map map1 = WXPayUtil.xmlToMap(res1); // 准备前台需要的参数APPID timestamp nonceStr package signType paySign Map<String,String> map2 = new HashMap<>(); // 获取之前返回的prepay_id String prepay_id = (String)map1.get("prepay_id"); map2.put("appId",payhospital.getAppid()); map2.put("nonceStr",suijishu); map2.put("package","prepay_id="+prepay_id); map2.put("signType","MD5"); map2.put("timeStamp",String.valueOf(WXPayUtil.getCurrentTimestamp())); //生成签名 //将集合M内非空参数值的参数按照参数名ASCII码从小到大排序 String paixu2 = GroupWeuxin.formatUrlMap(map2,false,false); // 拼接key String SignTemp2 = paixu2+"&key="+payhospital.getKeyy(); // MD5加密 并且转换为大写 String sign2 = Md5Util.getMD5String(SignTemp2).toUpperCase(); map2.put("paySign",sign2); // 判断签名是否正确 Boolean bool = WXPayUtil.isSignatureValid(map2,payhospital.getKeyy(),WXPayConstants.SignType.MD5); System.out.println("第二次:"+bool); 第一次成功返回prepay_id第二次签名出错,调用支付JSAPI缺少参数:total_fee 求解答!!!!!!!!!!!!!! 问答

微信支付提示:调用支付JSAPI缺少参数:total_fee

02-10

问题:在iOS版的微信上,调用微信支付,提示:**调用支付JSAPI缺少参数:total_fee**; 但是在Android版的微信上,调用微信支付,支付弹框一闪而过,没有任何提示。 参数值分别是: timeStamp:"1549735394" nonceStr:"mAXvtjnJ9TjfqjDc" package:"prepay_id%3Dwx1001103397948805d12203820692168854" signType: "MD5" paySign:"C87D3CE95B1A73B2F05D7F3404F712BC" 前端代码使用的接口是: ``` // 10 微信支付接口 // 10.1 发起一个支付请求 var useWXPay = function (data) { wx.chooseWXPay({ timeStamp : String(data["timestamp"]), nonceStr : data["nonce_str"], package : escape(data["package"]), signType : data["sign_type"], paySign : data["paySign"], success: function (res) { alert("成功") alert(res) }, fail: function (res) { alert("失败") alert(Object.keys(res)) alert(res.errMsg) } }); } ``` 或者H5的支付请求代码: ``` var useWXPay1 = function (data) { if (typeof WeixinJSBridge == "undefined") { if (document.addEventListener) { document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false); } else if (document.attachEvent){ document.attachEvent('WeixinJSBridgeReady', onBridgeReady); document.attachEvent('onWeixinJSBridgeReady', onBridgeReady); } } else { var appId = $.trim($("#appId").val()) WeixinJSBridge.invoke( 'getBrandWCPayRequest', { "appId" : appId, //公众号名称,由商户传入 "timeStamp" : data["timestamp"], //时间戳,自1970年以来的秒数 "nonceStr" : data["nonce_str"], //随机串 "package" : data["package"], "signType" : data["sign_type"], //微信签名方式 "paySign" : data["paySign"] //微信签名 }, function(res) { // alert("err_code=" + res.err_code) // alert("err_desc=" + res.err_desc) // alert("err_msg=" + res.err_msg) // alert(Object.keys(res)) if(res.err_msg == "get_brand_wcpay_request:ok" ) { // 使用以上方式判断前端返回,微信团队郑重提示: //res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。 } } ); } } ``` 在统一下单时,已传入openid 请求大神的帮助 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览