微信SDK与服务器开发,接入微信sdk支付

1、在微信开放平台申请app_id,app_key(差不多一个周才会通过审核)

app_id,app_key

2、开发流程

0ad8a9343552

image.png

0ad8a9343552

image.png

3、下面开始讲解配置工程

4.1 这里必须要有wxapi这个包名,同时必须有WXPayEntryActivity这个类名,否则无法调起微信支付,(开发文档没有标注,废了好大周章)

0ad8a9343552

image.png

4.2 支付成功通知:在WXPayEntryActivity的OnResp中处理,不能以微信返回的通知界面为准(我遇到的情况,网络不稳定的时候,微信返回界面提示支付失败,但是收到微信通知其实已经支付成功了),必须要去自己的服务器查询支付状态

@Override

public void onResp(BaseResp resp) {

Log.d(TAG, "onPayFinish, errCode = " + resp.errCode);

if (resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {

AlertDialog.Builder builder = new AlertDialog.Builder(this);

builder.setTitle(R.string.app_tip);

builder.setMessage(getString(R.string.pay_result_callback_msg, resp.errStr +";code=" + String.valueOf(resp.errCode)));

builder.show();

}

}

4.3 生成prepay_id,在服务器完成,由服务器去跟微信服务器交互,客户端不需要参与

/**

* 获取预支付订单号:

* prepay_id(服务器完成)!!!

* 注意:如果服务端开发文档跟客户端demo里的参数不一样,以demo里的参数为准,

* 否则服务器传过来的参数无法调起微信支付!!!

* */private String genProductArgs() {

StringBuffer xml = new StringBuffer();

try {

String nonceStr = genNonceStr();

xml.append("");

List packageParams = new LinkedList();

packageParams.add(new BasicNameValuePair("appid", Constants.APP_ID));

packageParams.add(new BasicNameValuePair("body", "APP pay test"));

/**这里用的是mach_id,跟sign签名时参数名不同,一定要注意*/

packageParams.add(new BasicNameValuePair("mch_id", Constants.MCH_ID));

packageParams.add(new BasicNameValuePair("nonce_str", nonceStr));

packageParams.add(new BasicNameValuePair("notify_url", "http://121.40.35.3/test"));-----通知我们的服务器,支付成功的时候

packageParams.add(new BasicNameValuePair("out_trade_no",genOutTradNo()));

packageParams.add(new BasicNameValuePair("spbill_create_ip","127.0.0.1"));

packageParams.add(new BasicNameValuePair("total_fee", "1"));

packageParams.add(new BasicNameValuePair("trade_type", "APP"));

String sign = genPackageSign(packageParams);

packageParams.add(new BasicNameValuePair("sign", sign));

String xmlstring =toXml(packageParams);

return xmlstring;

} catch (Exception e) {

Log.e(TAG, "genProductArgs fail, ex = " + e.getMessage());

returnnull;

}

}

4.4 获取二次签名sign

private void genPayReq() {

req.appId = Constants.APP_ID;

req.partnerId = Constants.MCH_ID;

req.prepayId = resultunifiedorder.get("prepay_id");

// req.packageValue = "prepay_id="+resultunifiedorder.get("prepay_id");

req.packageValue = "Sign=WXPay";

req.nonceStr = genNonceStr();

req.timeStamp = String.valueOf(genTimeStamp());

List signParams = new LinkedList();

signParams.add(new BasicNameValuePair("appid", req.appId));

signParams.add(new BasicNameValuePair("noncestr", req.nonceStr));/**

* 这里的package参数值必须是Sign=WXPay,否则IOS端调不起微信支付,

* (参数值是"prepay_id="+resultunifiedorder.get("prepay_id")的时候Android可以,IOS不可以)

*/

signParams.add(new BasicNameValuePair("package", req.packageValue));/**注意二次签名这里不再是mch_id,变成了prepayid;*/

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");

show.setText(sb.toString());

Log.e("orion", signParams.toString());

}

4.5 调起微信支付

private void sendPayReq() {

msgApi.registerApp(Constants.APP_ID);

msgApi.sendReq(req);

}

4.6 配置Manifest.xml,权限什么的按照文档的配置就行了

5、支付通知接口和退款接口按照开发文档即可

6、 在你的项目测试微信支付的时候,一定要用你自己的keystore签名出来测试,如果用debug.keystore肯定是不成功的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值