一、支付SDK簡介
要在APP中使用支付功能的話,必須要集成一些常用的第三方SDK。常用的支付SDK有:
支付寶、微信支付、百度錢包、網(wǎng)銀(易寶)等等。
其中第三方支付聚合SDK有,它們就像shareSDK一樣把一些常用的支付渠道集成好了:
ping++、Bmob
由于ping++更加專業(yè)因此我們使用它。
關(guān)于如何集成ping++這里只簡略說明,具體參考ping++官方文檔。
1、新建一個module,添加相關(guān)的jar包以及動態(tài)so庫,assest資源,res,java源代碼等所有東西進去,俗話說就是有什么copy什么。
需要注意的是:
作為library的module的清單文件不用寫Application節(jié)點也行,清單文件對于library來說然并卵。
清單文件中需要配置的東西一定要在主項目當中配置。
在Android Studio2.0中,新建JIN文件夾默認生成jni文件夾,但是我們需要的是jniLibs文件夾,很簡單,就是在主項目的build.gradle文件中:在配置的android節(jié)點下加入下面的內(nèi)容就ok,點擊sync以后會自動出現(xiàn)jniLibs文件夾。
sourceSets {
main {
jniLibs.srcDirs = ['libs'] //把jniLibs文件夾定義為libs文件夾
}
}
最后把jar包、so庫全部扔到libs文件夾(Project視圖才有libs文件夾)
2、配置主項目的清單文件,包括權(quán)限,activity,meta-data(APPKey)等等。
3、以上是常用的集成步驟,后續(xù)步驟按照官方文檔來。
至于如何去測試我們的支付功能呢?
我們不用真正去支付,ping++SDK提供我們開發(fā)者測試模式,通過測試模式就可以進行測試。正在應(yīng)用到實際當中的時候只需要把我們申請的APPKey替換為公司的APPKey并且進行審核驗證,就可以實現(xiàn)真正的支付功能了。支付相關(guān)的APPKey只有公司(具有一定資產(chǎn))才能申請,申請比較嚴格,這里就不說了。
二、支付流程 如下圖所示:
步驟可以總結(jié)為:
1、APP訪問自己的服務(wù)器API,提交訂單。這里需要注意的是用戶需要購買的商品信息是通過JSON字符串來進行提交的,因為JSON字符串可以傳遞一個長度不確定的List對象。
2、服務(wù)器返回支付憑證Charge給APP。(這里需要了解的是,服務(wù)器端也需要進行支付的相關(guān)開發(fā))支付憑證Charge是一個有一定格式的JSON字符串,
3、APP在拿到支付憑證之后,利用支付SDK的相關(guān)API發(fā)起支付請求。如下所示,代碼在官方文檔中有說明:
/** * 發(fā)起ping++SDK進行支付 * * @param createOrderRespMsg */ private void pay(CreateOrderRespMsg createOrderRespMsg) { Intent intent = new Intent(); String packageName = getPackageName(); ComponentName componentName = newComponentName(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把支付的結(jié)果(包括成功,失敗,相關(guān)支付APP沒有安裝,用戶取消了支付)返回給APP,代碼如下:
/** * 支付結(jié)果通知 * * @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根據(jù)支付SDK返回的結(jié)果去向自己的服務(wù)器請求,相應(yīng)地修改訂單狀態(tài)(例如修改為已付款)。
6、最后由服務(wù)器端返回給客戶端修改是否成功等信息,提示用戶操作是否成功等。
7、清空購物車中已經(jīng)購買的商品。
|