一酌媒、支付SDK簡介
要在APP中使用支付功能的話,必須要集成一些常用的第三方SDK迄靠。常用的支付SDK有:
支付寶秒咨、微信支付、百度錢包掌挚、網銀(易寶)等等雨席。
其中第三方支付聚合SDK有,它們就像shareSDK一樣把一些常用的支付渠道集成好了:
ping++吠式、Bmob
由于ping++更加專業(yè)因此我們使用它陡厘。
關于如何集成ping++這里只簡略說明,具體參考ping++官方文檔特占。
1糙置、新建一個module,添加相關的jar包以及動態(tài)so庫是目,assest資源谤饭,res,java源代碼等所有東西進去,俗話說就是有什么copy什么揉抵。
需要注意的是:
作為library的module的清單文件不用寫Application節(jié)點也行亡容,清單文件對于library來說然并卵。
清單文件中需要配置的東西一定要在主項目當中配置冤今。
在Android Studio2.0中闺兢,新建JIN文件夾默認生成jni文件夾,但是我們需要的是jniLibs文件夾戏罢,很簡單列敲,就是在主項目的build.gradle文件中:在配置的android節(jié)點下加入下面的內容就ok,點擊sync以后會自動出現jniLibs文件夾帖汞。
sourceSets {
main {
jniLibs.srcDirs = ['libs'] //把jniLibs文件夾定義為libs文件夾
}
}
最后把jar包戴而、so庫全部扔到libs文件夾(Project視圖才有l(wèi)ibs文件夾)
Android文件夾的創(chuàng)建方法如下:
2、配置主項目的清單文件翩蘸,包括權限所意,activity,meta-data(APPKey)等等催首。
3扶踊、以上是常用的集成步驟,后續(xù)步驟按照官方文檔來郎任。
至于如何去測試我們的支付功能呢秧耗?
我們不用真正去支付,ping++SDK提供我們開發(fā)者測試模式舶治,通過測試模式就可以進行測試分井。正在應用到實際當中的時候只需要把我們申請的APPKey替換為公司的APPKey并且進行審核驗證,就可以實現真正的支付功能了霉猛。支付相關的APPKey只有公司(具有一定資產)才能申請尺锚,申請比較嚴格,這里就不說了惜浅。
二瘫辩、支付流程
如下圖所示:
步驟可以總結為:
1、APP訪問自己的服務器API坛悉,提交訂單伐厌。這里需要注意的是用戶需要購買的商品信息是通過JSON字符串來進行提交的,因為JSON字符串可以傳遞一個長度不確定的List對象裸影。
2挣轨、服務器返回支付憑證Charge給APP。(這里需要了解的是空民,服務器端也需要進行支付的相關開發(fā))支付憑證Charge是一個有一定格式的JSON字符串刃唐,
3羞迷、APP在拿到支付憑證之后,利用支付SDK的相關API發(fā)起支付請求画饥。如下所示衔瓮,代碼在官方文檔中有說明:
/**
* 發(fā)起ping++SDK進行支付
*
* @param createOrderRespMsg
*/
private void pay(CreateOrderRespMsg createOrderRespMsg) {
Intent intent = new Intent();
String packageName = getPackageName();
ComponentName componentName = new ComponentName(packageName, packageName + ".wxapi.WXPayEntryActivity");
intent.setComponent(componentName);
intent.putExtra(PaymentActivity.EXTRA_CHARGE, JSONUtil.toJSON(createOrderRespMsg.getData().getCharge()));
startActivityForResult(intent, Constants.REQUEST_CODE_PAYMENT);
}
4、支付SDK把支付的結果(包括成功抖甘,失敗热鞍,相關支付APP沒有安裝,用戶取消了支付)返回給APP衔彻,代碼如下:
/**
* 支付結果通知
*
* @param requestCode
* @param resultCode
* @param data
*/
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
//支付頁面返回處理
if (requestCode == Constants.REQUEST_CODE_PAYMENT) {
if (resultCode == Activity.RESULT_OK) {
String result = data.getExtras().getString("pay_result");
if (result.equals("success")) {
changeOrderStatus(Constants.PAY_SUCCESS);//修改訂單狀態(tài)
} else if (result.equals("fail")) {
changeOrderStatus(Constants.PAY_FAILED);
} else if (result.equals("cancel")) {
changeOrderStatus(Constants.PAY_CANCEL);
} else if (result.equals("invalid")) {
changeOrderStatus(Constants.PAY_INVALID);
}
}
}
}
5薇宠、APP根據支付SDK返回的結果去向自己的服務器請求,相應地修改訂單狀態(tài)(例如修改為已付款)艰额。
6犯戏、最后由服務器端返回給客戶端修改是否成功等信息杭措,提示用戶操作是否成功等径密。
7盟广、清空購物車中已經購買的商品。
如果覺得我的文字對你有所幫助的話祖搓,歡迎關注我的公眾號:
我的群歡迎大家進來探討各種技術與非技術的話題狱意,有興趣的朋友們加我私人微信huannan88,我拉你進群交(♂)流(♀)拯欧。