Android 支付宝和微信支付集成

来源:互联网 发布:directx 9.0修复软件 编辑:程序博客网 时间:2024/05/22 10:24

场景

随着移动支付的兴起,在我们的app中,会经常有集成支付的需求.这时候一般都会采用微信和支付宝的sdk 来集成

支付宝支付

在使用支付宝支付的过程中,我们是在服务器端生成订单,客户端访问接口,得到订单信息.然后调起支付,支付成功后支付宝会分别 异步调用服务器端,同步调用客户端返回支付结果.

开发步骤

①注册支付宝账号——进行实名认证——提交审核资料——审核通过

支付宝无线快捷支付接口: 
b.alipay.com/order/productDetail.htm?productId=2014110308141993&tabId=4#ps-tabinfo-hash

注意

  1. 申请要上传你的apk和产品说明文档,产品截图、接口使用场景、资费说明等,审核通过后会得到商户PID和私钥。

  2. 开发者可以通过支付宝公钥验证消息来源,同时可使用自己的私钥对信息进行加密。

  3. 商户收款账号即用于接收付款的账号

② 下载官方Sdk Demo ,里面包含文档.将该Demo中的PID,支付宝收款账户和用户私钥替换. 运行demo,查看sdk调用方式,

PID对应的密钥一共有三种加密方式,分别是MD5、RSA、DSA。Java开发者需要将密钥转换成PKCS8格式,并将公钥上传到支付宝.生成方式见文档.[支付宝开放平台]

③ 导入项目,客户端调用,.首先将支付宝demo中的jar包导入到项目中,可以参照,demo中拼接参数,

支付宝demo类导入

//方法名称:payTask.pay//方法原型:PayTask payTask = new PayTask(activity);  String result = payTask.pay(orderInfo);//方法功能:提供给商户订单支付功能。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

请求参数以键值对的形式拼装到一个String中,参数具体说明详见官方文档.

注意

  1. 除去sign、sign_type两个参数外,其他需要使用到的参数皆是要签名的参数
  2. sign值要做utf-8 URLencode

④ 修改Manifest,添加com.alipay.sdk.app.H5PayActivityuses-permission,并在proguard-project.txt中添加相关的混淆规则即可.

⑤回调处理,详见 支付宝同步通知参数说明.out_trade_no可以作为唯一标志和服务器端进行交互,当支付宝同步 通知后,客户端通过out_trade_no询问服务器端是否支付成功,因为真正的成功标志是需要服务器端来验证的.

 public AliPayResultS(String result) {        if (TextUtils.isEmpty(result))            return;        String[] resultParams = result.split("&");        for (String resultParam : resultParams) {            if (resultParam.startsWith("out_trade_no")) {                out_trade_no = gatValue(resultParam, "out_trade_no");            }        }    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

微信支付

同样,有了支付宝支付,呢么微信支付也不可缺少,微信支付和支付宝支付流程,大体相同,通过服务器端获取订单信息返回给客户端,客户端调用sdk进行支付,支付完成后进行同步和异步回调.

微信开放平台Android接入指南: 
open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=1417751808&token=&lang=zh_CN

开发步骤

①获取appId 
同样需要获取appid,登记并选择移动应用进行设置后,将该应用提交审核,只有审核通过并获取appId的应用才能进行开发。

②下载Android 微信支付demo. 
微信支付

我们所需要关注的依旧是PayActivity.使用微信的登陆和支付,大家都知道,需要在项目下新建一个wxapi文件夹来实现回调.

③项目集成,首先我们需要将libammsdk.jar导入到lib目录下,这个是核心jar包.同时修改Manifest

  <activity            android:name=".wxapi.WXPayEntryActivity"            android:exported="true"            android:launchMode="singleTop"/>
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

④接口调用.

首先我们需要初始化一个IWXAPI api,并注册到应用,

api.registerApp(Constants.APP_ID); PayReq req = new PayReq();//....拼接req参数api.sendReq(req);// 调用支付
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

注意

  1. 微信支付并不会像支付宝那样,支付宝没有安装默认会调用H5PayActivity
  2. 微信支付前,最好判断下是否安装微信
//判断是否安装微信private boolean isWXAppInstalledAndSupported(IWXAPI msgApi) {        msgApi.registerApp(Constants.APP_ID);        boolean sIsWXAppInstalledAndSupported = msgApi.isWXAppInstalled()                && msgApi.isWXAppSupportAPI();        return sIsWXAppInstalledAndSupported;    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

⑤支付回调.

在支付回调类WXPayEntryActivityonResp(BaseResp resp)方法中我们可以得到 客户端 和服务器 唯一标志prepayid参数,来实现支付成功的后续处理.

  // 支付成功                if (resp instanceof com.tencent.mm.sdk.modelpay.PayResp) {                    com.tencent.mm.sdk.modelpay.PayResp payResp = (PayResp) resp;                    String prepayId = payResp.prepayId;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

ps: 微信支付中需要注意的是支付回调方法.支付回调必须在项目中创建一个wxapi目录,并命名为WXPayEntryActivity(包名或类名不一致会造成无法回调),回调方法中获取prepayId.

 // 第三方应用发送到微信的请求处理后的响应结果,会回调到该方法    @Override    public void onResp(BaseResp baseResp) {//        String result = "";        switch (baseResp.errCode) {            case BaseResp.ErrCode.ERR_OK://                result = "发送成功";            {                Intent intent = new Intent(Constants.payAction);                intent.putExtra(Constants.prepayId, ((PayResp) baseResp).prepayId);                mLocalBroadcastManager.sendBroadcast(intent);            }            break;            case BaseResp.ErrCode.ERR_USER_CANCEL://                result = "发送取消";                break;            case BaseResp.ErrCode.ERR_AUTH_DENIED://                result = "发送被拒绝";                break;            default://                result = "发送返回";                break;        }        finish();    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

最后,微信支付不能使用debug的,因为要验证签名等.否则支付不成功

封装

为了方便,将上面代码进行封装ShareLoginPay,只需配置好相关的 appid ,即可使用, 
以微信支付为例

//初始化appid PayBlock.getInstance().initWechatPay("");//调起支付String payInfo = "";            PayReq req = WechatOderInfo.getWeixinPayReq(payInfo);                WxpayUtil.weixinPay(req, new WxpayResultListener() {                    @Override public void payResult(PayResp payResp) {                        String prepayId = payResp.prepayId;                        Toast.makeText(MainActivity.this, "prepayid--->" + prepayId,                            Toast.LENGTH_SHORT).show();                    }                    @Override public void onError(int errCode) {                        Toast.makeText(MainActivity.this, "onError()-->" + errCode,                            Toast.LENGTH_SHORT).show();                    }                    @Override public void onCancel() {                        Toast.makeText(MainActivity.this, "onCancel()", Toast.LENGTH_SHORT).show();                    }                    @Override public void notSupport() {                        Toast.makeText(MainActivity.this, "没有安装微信,或版本太低", Toast.LENGTH_SHORT)                            .show();                    }                });
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

完整demo:

0 6