鴻蒙Next-支付寶SDK接入教程

安辉發表於2024-08-20

App適配鴻蒙Next,開始做支付功能了,目前來說只有支付寶支援鴻蒙Next,微信還沒上架,但是支付寶官方的文件跟Demo都很老,下載官方的Demo用最新版的DevEco-Studio匯入都不成功。

後面在OpenHarmony三方庫中心倉找到了最新的程式碼:

https://ohpm.openharmony.cn/#/cn/detail/@cashier_alipay%2Fcashiersdk

官方Demo地址:

https://alidocs.dingtalk.com/i/nodes/qnYMoO1rWxrkmoj2IOpZR6yaJ47Z3je9?iframeQuery=utm_source%3Dportal%26utm_medium%3Dportal_recent&rnd=0.2928087218087806

程式碼實現

首先依賴支付寶SDK,開啟終端,cd到專案資料夾,輸入命令,如果ohpm沒有加入環境變數的話需要手動加一下:

ohpm i @cashier_alipay/cashiersdk

把OrderInfoUtil跟SignUtils檔案複製到你的專案中來,當點選介面上的支付按鈕時,先請求伺服器,獲取支付資訊,然後呼叫new Pay().pay(orderInfo, true)進行支付。PayInfo物件所有資訊都應該伺服器返回。

///這個支付資訊物件的所有值都應該伺服器返回
let obj = new PayInfo();//支付資訊
obj.appId = "1111111111111";
obj.orderId = "1111111111"
obj.productName = "1年VIP"
obj.amount = 10
obj.notifyUrl = 'https://www.huawei.com'
obj.rsaPrivate = "MIICXQIBAA"

OrderInfoUtil.getOrderInfo(obj).then(orderInfo=>{
    // orderInfo 由服務端生成
    // 第二個引數 控制是否展示支付寶loading
    new Pay().pay(orderInfo, true).then((result) => {
        let message =
            `resultStatus: ${result.get('resultStatus')} memo: ${result.get('memo')} result: ${result.get('result')}`;
        console.log("支付結果:"+message);

        if (result.get('resultStatus') == '9000') { //支付成功
            console.log("支付成功");
        }else{
            console.log("支付失敗");
        }
    }).catch((error: BusinessError) => {
        console.log(error.message);
    });
})

效果圖

注意事項

官方的Demo是沒有notify_url這個引數的,但是我發現不加上notify_url的話,支付成功不會回撥我們的業務伺服器,於是我對比安卓的程式碼給加上的,還有notify_url必須要加在method引數後面,因為計算簽名的時候引數key是需要排序的。

如果複製我的OrderInfoUtil類是已經修改過的,如果複製官方Demo中的OrderInfoUtil類需要注意一下。

/**
 * 生成訂單引數Map,這個Key一定要排序,例如b開頭的key一定要寫在c開頭的key前面
 * @param payInfo
 * @returns
 */
static buildOrderParamMap(payInfo:PayInfo): Map<string, string> {
    const keyValues = new Map<string, string>()
    keyValues.set('app_id', payInfo.appId);

    // 商戶網站唯一訂單號
    let orderId =payInfo.orderId;
    if(orderId == undefined || orderId==''){
        orderId = util.generateRandomUUID(true);
    }

    // 不能包含中文,否則加密會有問題。。。。。。。。。。。。
    keyValues.set('biz_content', "{\"timeout_express\":\"30m\",\"product_code\":\"QUICK_MSECURITY_PAY\",\"total_amount\":\""+
    payInfo.amount+"\",\"subject\":\""+payInfo.productName+"\",\"body\":\""+
    payInfo.productName+"\",\"out_trade_no\":\"" + orderId +  "\"}");
    keyValues.set('charset', 'utf-8');
    keyValues.set('method', 'alipay.trade.app.pay');
    keyValues.set('notify_url',payInfo.notifyUrl);//支付成功後,支付寶會訪問這個通知URL
    keyValues.set('sign_type', 'RSA2');
    keyValues.set('timestamp', '2016-07-29 16:55:53');
    keyValues.set('version', '1.0');
    return keyValues;
}

原始碼下載

https://github.com/ansen666/alipay_harmony_sdk

如果您想第一時間看我的後期文章,掃碼關注公眾號

      安輝程式設計筆記 - 開發技術分享
             掃描二維碼加關注

相關文章