找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2875|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

商城開發(fā)筆記-16-支付功能實(shí)現(xiàn)

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:109770 發(fā)表于 2016-3-22 17:33 | 只看該作者 回帖獎勵 |倒序?yàn)g覽 |閱讀模式
一、支付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源代碼等所有東西進(jìn)去,俗話說就是有什么copy什么。

需要注意的是:
作為librarymodule的清單文件不用寫Application節(jié)點(diǎn)也行,清單文件對于library來說然并卵。

清單文件中需要配置的東西一定要在主項(xiàng)目當(dāng)中配置。

Android Studio2.0中,新建JIN文件夾默認(rèn)生成jni文件夾,但是我們需要的是jniLibs文件夾,很簡單,就是在主項(xiàng)目的build.gradle文件中:在配置的android節(jié)點(diǎn)下加入下面的內(nèi)容就ok,點(diǎn)擊sync以后會自動出現(xiàn)jniLibs文件夾。
sourceSets {
        main {
            jniLibs.srcDirs = ['libs']                //jniLibs文件夾定義為libs文件夾
        }
    }
最后把jar包、so庫全部扔到libs文件夾(Project視圖才有libs文件夾)


2、配置主項(xiàng)目的清單文件,包括權(quán)限,activitymeta-dataAPPKey)等等。

3、以上是常用的集成步驟,后續(xù)步驟按照官方文檔來。

       至于如何去測試我們的支付功能呢?
       我們不用真正去支付,ping++SDK提供我們開發(fā)者測試模式,通過測試模式就可以進(jìn)行測試。正在應(yīng)用到實(shí)際當(dāng)中的時候只需要把我們申請的APPKey替換為公司的APPKey并且進(jìn)行審核驗(yàn)證,就可以實(shí)現(xiàn)真正的支付功能了。支付相關(guān)的APPKey只有公司(具有一定資產(chǎn))才能申請,申請比較嚴(yán)格,這里就不說了。


二、支付流程
如下圖所示:


步驟可以總結(jié)為:

1、APP訪問自己的服務(wù)器API,提交訂單。這里需要注意的是用戶需要購買的商品信息是通過JSON字符串來進(jìn)行提交的,因?yàn)?/font>JSON字符串可以傳遞一個長度不確定的List對象。

2、服務(wù)器返回支付憑證ChargeAPP。(這里需要了解的是,服務(wù)器端也需要進(jìn)行支付的相關(guān)開發(fā))支付憑證Charge是一個有一定格式的JSON字符串,

3APP在拿到支付憑證之后,利用支付SDK的相關(guān)API發(fā)起支付請求。如下所示,代碼在官方文檔中有說明:
/**
* 發(fā)起ping++SDK進(jìn)行支付
*
* @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)購買的商品。



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表