Android 微信支付统一下单成功,成功返回prepayid,启动支付, 拉取支付页面失败,直接调用回调页面,返回错误码-1,在网上找了很久的,很多都不能直接解决问题
1.检查appID
2.商户ID
3.应用签名必须是正式包的签名
4..秘钥:是开放平台开通微信支付后,会返回商户ID,登录微信商户号后,找到账户设置 -> 密码安全 -> API安全 -> API密钥;微信支付使用的KEY 是这个,可不要设置错了,不然会统一下单失败,返回签名错误。
网上很多都是说应用签名大小写,实际上跟这个没有太大关系,
还有demo中WXPayEntryActivity,清单文件中scheme 的设置,实际跟这里也没有多大关系。
实际解决办法是:
调取支付功能的时候,主要问题是sign的问题,大部分可能都会直接使用微信支付返回的sign这个值,
request.sign= map.get("sign");实际上问题就出在这里了,因为你调取支付的时候,会生成一个时间戳,可是微信支付返回的sign中,咱们并不知道微信后台设置的时间戳是什么。所以直接使用这个sign,调用支付会直接返回-1。应该自己重新生成一个sign,不使用微信返回的sign,就可以直接拉起支付页面了。
SortedMap params = new TreeMap();
PayReq request = new PayReq();
request.appId = APPID;
request.partnerId =MCH_ID;
request.prepayId= map.get("prepay_id");
request.packageValue = "Sign=WXPay";
request.nonceStr= map.get("nonce_str");
request.timeStamp= (System.currentTimeMillis()/1000)+"";
params.put("appid", request.appId);
params.put("partnerid", request.partnerId);
params.put("prepayid", request.prepayId);
params.put("package", request.packageValue);
params.put("noncestr", request.nonceStr);
params.put("timestamp", request.timeStamp);
String sign = createSign( params);
request.sign= sign;
msgApi.sendReq(request);
public static String createSign(SortedMap parameters){
StringBuffer sb = new StringBuffer();
Set es = parameters.entrySet();
Iterator it = es.iterator();
while(it.hasNext()) {
Map.Entry entry = (Map.Entry)it.next();
String k = (String)entry.getKey();
Object v = entry.getValue();
if(null != v && !"".equals(v)
&& !"sign".equals(k) && !"key".equals(k)) {
sb.append(k + "=" + v + "&");
}
}
sb.append("key=" + API_KEY);
String sign = MD5Utils.encode(sb.toString()).toUpperCase();
return sign;
}
必须是正式打包的apk,就是必须与你申请应用的应用签名一致,不然是不会成功的。
这是我发现的一直返回-1,不调用支付页面的解决办法。希望对各位有用。