前言
很多APP都需要支付功能,国内一般就是支付宝和微信了。目前这2种接入方式对于APP端来说都已经比较方便了,因为大部分的安全校验之类的逻辑都在服务端。
APP端总结起来就是三步走:
- 接入支付的库
- 接受服务端的订单信息,发起调用支付宝和微信
- 接收支付宝和微信的回调
支付宝接入
首先是接入支付宝的aar文件
比较坑的是支付宝还需要下载aar文件导入,而不是gradle里面一行依赖就能搞定的。
我们需要去官网下载最新的DEMO和SDK,官网地址在这里
然后把下载下来的aar包,放到项目目录下面的 libs 目录下,通过下面的gradle依赖进来
// 支付宝 SDK AAR 包所需的配置
compile(name: 'alipaySdk-15.6.0-20190226104104-noUtdid', ext: 'aar')
调用支付宝SDK的方法发起支付
调用支付宝SDK发起支付,只需要一个参数,就是服务端返回的订单信息。所以这里的支付顺序是先要我们调用服务端的接口创建一个订单,然后服务端把订单信息返回给我们,我们APP拿着这个订单信息去调用支付宝支付。
//下面的orderInfo就是咱自己的服务端返回的订单信息,里面除了订单ID等,还有签名等安全信息
//使用方式基本按照支付宝的DEMO里面就行了
final Runnable payRunnable = new Runnable() {
@Override
public void run() {
PayTask alipay = new PayTask(PayDemoActivity.this);
Map<String, String> result = alipay.payV2(orderInfo, true);
Log.i("msp", result.toString());
Message msg = new Message();
msg.what = SDK_PAY_FLAG;
msg.obj = result;
mHandler.sendMessage(msg);
}
};
// 必须异步调用
Thread payThread = new Thread(payRunnable);
payThread.start();
由上面的调用可见,支付宝是通过消息机制来接收回调的,所以我们得在Handler的消息中接收回调信息。
private Handler mHandler = new Handler() {
@SuppressWarnings("unused")
public void handleMessage(Message msg) {
switch (msg.what) {
case SDK_PAY_FLAG: {
//这里接收支付宝的回调信息
//需要注意的是,支付结果一定要调用自己的服务端来确定,不能通过支付宝的回调结果来判断
break;
}
default:
break;
}
};
};
需要注意的是,支付结果一定要调用自己的服务端来确定,不能通过支付宝的回调结果来判断!
其他
实际情况里需要考虑用户手机上有没有安装过支付宝
- 已经安装过支付宝,会直接调用支付宝支付
- 没有安装支付宝,会调起支付宝的H5页面支付
以上就是支付宝的接入了,步骤还是比较简单的,也没有什么坑。下面的微信支付就有坑了...
微信支付接入
接入微信的SDK
官网在这
相比于支付宝,微信接入SDK就比较简单了,一行代码搞定
//微信支付SDK
compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+'
这里需要注意的是,微信的SDK里面支付和社交登录等这些是集成在一起的,无法分开。所以如果项目里之前已经集成过微信登录的话就不需要重复集成了!
调用微信SDK发起支付
String content = ... (这个是服务端返回的订单信息)
//需要一个注册微信支付的APPID
IWXAPI api = WXAPIFactory.createWXAPI(mContext, APPID);
JSONObject json = new JSONObject(content);
PayReq req = new PayReq();
req.appId = json.getString("appid");
req.partnerId = json.getString("partnerid");
req.prepayId = json.getString("prepayid");
req.nonceStr = json.getString("noncestr");
req.timeStamp = json.getString("timestamp");
req.packageValue = json.getString("package");
req.sign = json.getString("sign");
api.sendReq(req); //这里就发起调用微信支付了
接收微信支付的回调
可以看到上面的代码和支付宝就不一样了,没有用Handler。
微信支付比较特殊的一个地方是需要我们用一个特殊的Activity来接收回调的信息。这个处理不好很容易就碰到接收不到回调的情况。
我们需要新建一个名叫 WXPayEntryActivity 的Activity,内容的话可以参考微信SDK里面的。需要注意的有几点:
WXPayEntryActivity这个Activity的路径要符合要求,比如APP的包名是 com.niubi.company ,那这个Activity的路径就需要是 com.niubi.company.wxapi.WXPayEntryActivity
这个WXPayEntryActivity当然需要在 AndroidManifest 文件中注册
<activity
android:name=".wxapi.WXPayEntryActivity"
android:exported="true"
android:launchMode="singleTop"/>
特别需要注意的是上面的 exported 属性和 launchMode 属性一定要加上,否则是接收不到回调的
我们在支付完成以后,一般是希望直接回到我们自己的应用里面。这个时候我们就需要让上面的 WXPayEntryActivity 不显示,否则就会闪一下或是停留在这个黑黑页面。
不显示的话要注意2点,一个是不要有布局,另一个就是要及时的 finish 掉这个Activity
public class WXPayEntryActivity extends Activity implements IWXAPIEventHandler{
...
@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, String.valueOf(resp.errCode)));-->
<!--builder.show();-->
//这里肯定不能是像上面的DEMO一样弹出对话框了,而是通知我们发起支付调用的页面
//然后及时finish掉这个页面,贴个伪代码:
sendPayNotice()
finish();
}
}
}
其他
同样的,微信支付成功与否,也要通过调用自己的服务端来查看,而不能依赖微信的回调状态,这个要切记。
总结
以上就是微信和支付宝的支付接入,基本上按照上述步骤都不会有问题了。特别是微信支付,一定要特别注意文中提到的注意点,那些都是踩过的坑啊!