Android 支付宝和微信支付集成

场景

随着移动支付的兴起,在我们的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);

//方法功能:提供给商户订单支付功能。

请求参数以键值对的形式拼装到一个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");
            }
        }

    }

微信支付

同样,有了支付宝支付,呢么微信支付也不可缺少,微信支付和支付宝支付流程,大体相同,通过服务器端获取订单信息返回给客户端,客户端调用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"/>

④接口调用.

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

api.registerApp(Constants.APP_ID); 
PayReq req = new PayReq();
//....拼接req参数
api.sendReq(req);// 调用支付
注意
  1. 微信支付并不会像支付宝那样,支付宝没有安装默认会调用H5PayActivity
  2. 微信支付前,最好判断下是否安装微信
//判断是否安装微信
private boolean isWXAppInstalledAndSupported(IWXAPI msgApi) {
        msgApi.registerApp(Constants.APP_ID);

        boolean sIsWXAppInstalledAndSupported = msgApi.isWXAppInstalled()
                && msgApi.isWXAppSupportAPI();

        return sIsWXAppInstalledAndSupported;
    }

⑤支付回调.

在支付回调类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;

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();
    }

最后,微信支付不能使用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();
                    }
                });

完整demo:

payapp

  • 6
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值