[AliPay]支付寶支付接入

文章涉及的demo在Github LQThirdParty, 歡迎Star | Fork

一. 新建APP及安全配置

首先到螞蟻金服開發(fā)平臺注冊賬號, 并新建應用, 配置相關(guān)的安全數(shù)據(jù), 具體可參考其官方文檔一步步進行操作, 這里不再贅述.

二. 集成SDK及配置工程

2.1 集成SDK

下載iOS 端SDK, 將解壓后iOSDemo 中的以下兩個文件添加到項目:

AlipaySDK.bundle
AlipaySDK.framework

注意: 如果使用Xcode 9 以上版本, 直接拖進去, 并不會形成引用, 會報找不到文件的錯誤, 這時可以刪除引用, 即將文件從項目中刪除:

屏幕快照 2017-11-21 上午11.45.26.png

點擊 Remove References, 然后右鍵 Add Files..., 重新添加進來即可.

2.2 配置

添加系統(tǒng)依賴庫:
在Build Phases -> Link Binary With Libraries中:

CoreMotion.framework
CFNetwork.framework
Foundation.framework
UIKit.framework
CoreGraphices.framework
CoreText.framework
QuartzCore.framework
CoreTelephony.framework
SystemConfiguration.framework
libz.tbd
libc++.tbd

屏幕快照 2017-11-21 上午11.51.59.png

在Xcode 9以上版本添加系統(tǒng)庫的時候, 會在項目根目錄新建一個Frameworks文件夾, 如上圖所示, 添加系統(tǒng)庫的時候, 會出現(xiàn)在這里, 而在 Link Binary With Libraries 中并沒有顯示添加的系統(tǒng)庫, 這樣在編譯的時候還是會出錯的, 如果第一次添加沒有, 可以再添加一次, 務必保證如下圖所示:


Link Binary With Libraries

添加搜索路徑: Header Search Paths
在Build Settings 中搜索search, 找到 Header Search Paths

Header Search Paths

添加 $(SRCROOT)/項目名稱, 如果已有, 則不需添加;

此時編譯一下, 應該不會再報錯了.

添加URL Scheme
在Info -> URL Types 中, 點擊 + 新加一個URL Scheme, 用于支付成功會返回APP.

這里的URL Schemes要根據(jù)實際商戶的app中填寫的獨立scheme,建議跟商戶的app有一定的標示度,要做到和其他的商戶app不重復,否則可能會導致支付寶返回的結(jié)果無法正確跳回商戶app。

這個值和發(fā)起支付時接口中的參數(shù) appScheme 保持一致.

添加URL Scheme

到此, 相關(guān)的配置就完成了, 下面就是使用相關(guān)的API實現(xiàn)相應的功能.

PS: 如果是Swift項目, 在使用相關(guān)API的時候, 需要新建橋接頭文件, 或者在已有橋接頭文件內(nèi)引用其頭文件:

#import <AlipaySDK/AlipaySDK.h>

三. 支付

支付寶的大部分內(nèi)容都是由后臺完成的, 包括訂單生成, 加簽, 加密, 秘鑰驗證等一些安全操作, 最終生成一個編碼后的字符串返回給APP, 用于吊起支付寶, 發(fā)起支付.

PS: 如果這些操作, 后臺都沒有做, 參考支付寶官方demo, 一步步自己來吧, 官方demo中各種加簽, 加密工具都已經(jīng)封裝好, 自己填上相關(guān)的參數(shù)即可, 但是不建議APP端去做這些.

3.1 回調(diào)處理

class func open(url: URL, success: ((_ info: [String: String]) -> Void)? = nil, failed: (()->Void)? = nil) {
        
        if let host = url.host {
            if host == "safepay" {
               AlipaySDK.defaultService().processOrder(withPaymentResult: url, standbyCallback: { (info) in
                self.checkResult(info as? [String : Any], success: success, failed: failed)
                })
            }
        }
    }

iOS 9以上版本可在下面的方法里設置:

func application(_ app: UIApplication, open url: URL, options: [UIApplicationOpenURLOptionsKey : Any] = [:]) -> Bool {
        
        LQAliPay.open(url: url, success: { (result) in
            //處理支付成功結(jié)果
        }) {
            // 支付失敗或支付異常, 這里的支付失敗不一定是失敗, 具體結(jié)果可在后臺驗證
        }
        return true
    }

如果需要兼容iOS 9以下版本, 可在下面的方法內(nèi)處理:

func application(_ application: UIApplication, open url: URL, sourceApplication: String?, annotation: Any) -> Bool {
        
        LQAliPay.open(url: url, success: { (result) in
            //處理支付成功結(jié)果
        }) {
            // 支付失敗或支付異常, 這里的支付失敗不一定是失敗, 具體結(jié)果可在后臺驗證
        }
        return true
    }
發(fā)起支付

在發(fā)起支付的事件里添加以下方法的調(diào)用:

class func pay(order: String, appScheme scheme: String, success: ((_ info: [String: String]) -> Void)? = nil, failed: (()->Void)? = nil) {
        
        AlipaySDK.defaultService().payOrder(order, fromScheme: scheme) { (info) in
            self.checkResult(info as? [String : Any], success: success, failed: failed)
        }
    }

后記

關(guān)于支付寶返回的支付結(jié)果處理, 這里有一個大坑, 具體請參考我的另一篇文章: [iOS]關(guān)于支付寶支付返回值的坑

文章涉及的demo在Github LQThirdParty, 歡迎Star | Fork

(完)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容