随着移动支付的兴起,在我们的app中,会经常有集成支付的需求.这时候一般都会采用微信和支付宝的sdk 来集成
在使用支付宝支付的过程中,我们是在服务器端生成订单,客户端访问接口,得到订单信息.然后调起支付,支付成功后支付宝会分别 异步调用服务器端,同步调用客户端返回支付结果.
①注册支付宝账号——进行实名认证——提交审核资料——审核通过
支付宝无线快捷支付接口:
b.alipay.com/order/productDetail.htm?productId=2014110308141993&tabId=4#ps-tabinfo-hash
申请要上传你的apk和产品说明文档,产品截图、接口使用场景、资费说明等,审核通过后会得到商户PID和私钥。
开发者可以通过支付宝公钥验证消息来源,同时可使用自己的私钥对信息进行加密。
② 下载官方Sdk Demo
,里面包含文档.将该Demo中的PID,支付宝收款账户和用户私钥替换. 运行demo,查看sdk调用方式,
PID对应的密钥一共有三种加密方式,分别是MD5、RSA、DSA。Java开发者需要将密钥转换成PKCS8格式,并将公钥上传到支付宝.生成方式见文档.[支付宝开放平台]
③ 导入项目,客户端调用,.首先将支付宝demo中的jar
包导入到项目中,可以参照,demo中拼接参数,
//方法名称:payTask.pay
//方法原型:
PayTask payTask = new PayTask(activity); String result = payTask.pay(orderInfo);
//方法功能:提供给商户订单支付功能。
请求参数以键值对的形式拼装到一个String中,参数具体说明详见官方文档.
④ 修改Manifest
,添加com.alipay.sdk.app.H5PayActivity
和uses-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的应用才能进行开发。
我们所需要关注的依旧是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);// 调用支付
//判断是否安装微信
private boolean isWXAppInstalledAndSupported(IWXAPI msgApi) {
msgApi.registerApp(Constants.APP_ID);
boolean sIsWXAppInstalledAndSupported = msgApi.isWXAppInstalled()
&& msgApi.isWXAppSupportAPI();
return sIsWXAppInstalledAndSupported;
}
⑤支付回调.
在支付回调类WXPayEntryActivity
的onResp(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