微信支付的集成步奏
- 1 集成jar包,配置文件
- 2 获取prepare_id等支付api入参
- 3 打包测试
三方平台的配置
首先是要在微信开放平台注册一个新项目,需要获得的信息是App_ID,需要配置的信息是自己项目的包名和签名(注意:签名文件来自Android打包时用的keystore文件里面解析的MD5信息,记得去掉冒号,全部小写)
在开通支付功能的时候会涉及到微信商户平台开通的信息,微信平台会发邮件里面附带一个商户号信息和密钥(可以在商户平台重新配置)
项目的导包和配置
libammsdk.jar,httpcore-4.2.4.jar,httpclient-4.2.5,Jar包下载地址第一个是支付的核心,后面2个在用到BasicNameValuePair这个类时才会需要,在有些做法中用不到,下面的介绍会提及
WxPayEntryActivity是控制微信支付回调的类,包名和包目录要跟微信支付开发文档保持一致 如图,负责大概率会出错。
prepare_id等支付api信息的生成
第一种标准做法,商户id和秘密都存放在后台,所有的信息都由后台返回,移动端只发起请求(这个做法就不需要引入上面的第二第三个包)
public PayWithWechat(Context context, PayResultBean payResultBean){
msgApi = WXAPIFactory.createWXAPI(context, null);
msgApi.registerApp(Constants.APP_ID);
this.payResultBean=payResultBean;
genPayReq();
//发起支付请求
msgApi.sendReq(req);
}
//支付请求的参数均由后台提供 缺一不可
private void genPayReq(){
req.appId=payResultBean.appid;
req.partnerId=payResultBean.partnerid;
req.prepayId=payResultBean.prepayid;
req.packageValue=payResultBean.packagename;
req.nonceStr=payResultBean.noncestr;
req.timeStamp=payResultBean.timestamp;
req.sign=payResultBean.sign;
}
第二种就麻烦一些 只提供了prepare_id 其他的支付信息都需要自己生成
private void genPayReq() {
req.appId = Constants.APP_ID;
//商户id
req.partnerId = Constants.MCH_ID;
Log.e("预支付id", prepay_id + "");
req.prepayId = prepay_id;
req.packageValue = "Sign=WXPay";
req.nonceStr = genNonceStr();
req.timeStamp = String.valueOf(genTimeStamp());
List<NameValuePair> signParams = new LinkedList<NameValuePair>();
signParams.add(new BasicNameValuePair("appid", req.appId));
signParams.add(new BasicNameValuePair("noncestr", req.nonceStr));
signParams.add(new BasicNameValuePair("package", req.packageValue));
signParams.add(new BasicNameValuePair("partnerid", req.partnerId));
signParams.add(new BasicNameValuePair("prepayid", req.prepayId ));
signParams.add(new BasicNameValuePair("timestamp", req.timeStamp));
req.sign = genAppSign(signParams);
sb.append("sign\n" + req.sign + "\n\n");
Log.e("orion", signParams.toString());
}
private String genNonceStr() {
Random random = new Random();
return MD5.getMessageDigest(String.valueOf(random.nextInt(10000)).getBytes());
}
private long genTimeStamp() {
return System.currentTimeMillis() / 1000;
}
private String genAppSign(List<NameValuePair> params) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < params.size(); i++) {
sb.append(params.get(i).getName());
sb.append('=');
sb.append(params.get(i).getValue());
sb.append('&');
}
sb.append("key=");
//密钥
sb.append(Constants.API_KEY);
this.sb.append("sign str\n" + sb.toString() + "\n\n");
String appSign = MD5.getMessageDigest(sb.toString().getBytes()).toUpperCase();
Log.e("orionAppSign", appSign);
return appSign;
}
调试支付
微信支付相较支付宝麻烦在于必须打包测试,用到的keyStore文件要与微信开放平台相符,支付失败errcode=-1主要就是包名和签名出错的问题,也可以从支付请求参数去排查原因。当支付成功,但是app上存在数据没改变的情况,极大可能是回调地址设置原因,例如可能请求是https回调地址却是htttp,需要找后台沟通。支付成功和支付失败之后的逻辑在WxPayEntryActivity中(这个是默认的,相较直接在当前页面做一些逻辑处理也比较麻烦)