文章涉及的demo在Github LQThirdParty, 歡迎Star | Fork
一. 新建APP及安全配置
首先到螞蟻金服開發平臺注冊賬號, 并新建應用, 配置相關的安全數據, 具體可參考其官方文檔一步步進行操作, 這里不再贅述.
二. 集成SDK及配置工程
2.1 集成SDK
下載iOS 端SDK, 將解壓后iOSDemo 中的以下兩個文件添加到項目:
AlipaySDK.bundle
AlipaySDK.framework
注意: 如果使用Xcode 9 以上版本, 直接拖進去, 并不會形成引用, 會報找不到文件的錯誤, 這時可以刪除引用, 即將文件從項目中刪除:
點擊 Remove References, 然后右鍵 Add Files..., 重新添加進來即可.
2.2 配置
添加系統依賴庫:
在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
在Xcode 9以上版本添加系統庫的時候, 會在項目根目錄新建一個Frameworks文件夾, 如上圖所示, 添加系統庫的時候, 會出現在這里, 而在 Link Binary With Libraries 中并沒有顯示添加的系統庫, 這樣在編譯的時候還是會出錯的, 如果第一次添加沒有, 可以再添加一次, 務必保證如下圖所示:
添加搜索路徑: Header Search Paths
在Build Settings 中搜索search, 找到 Header Search Paths
添加 $(SRCROOT)/項目名稱, 如果已有, 則不需添加;
此時編譯一下, 應該不會再報錯了.
添加URL Scheme
在Info -> URL Types 中, 點擊 + 新加一個URL Scheme, 用于支付成功會返回APP.
這里的URL Schemes要根據實際商戶的app中填寫的獨立scheme,建議跟商戶的app有一定的標示度,要做到和其他的商戶app不重復,否則可能會導致支付寶返回的結果無法正確跳回商戶app。
這個值和發起支付時接口中的參數 appScheme 保持一致.
到此, 相關的配置就完成了, 下面就是使用相關的API實現相應的功能.
PS: 如果是Swift項目, 在使用相關API的時候, 需要新建橋接頭文件, 或者在已有橋接頭文件內引用其頭文件:
#import <AlipaySDK/AlipaySDK.h>
三. 支付
支付寶的大部分內容都是由后臺完成的, 包括訂單生成, 加簽, 加密, 秘鑰驗證等一些安全操作, 最終生成一個編碼后的字符串返回給APP, 用于吊起支付寶, 發起支付.
PS: 如果這些操作, 后臺都沒有做, 參考支付寶官方demo, 一步步自己來吧, 官方demo中各種加簽, 加密工具都已經封裝好, 自己填上相關的參數即可, 但是不建議APP端去做這些.
3.1 回調處理
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
//處理支付成功結果
}) {
// 支付失敗或支付異常, 這里的支付失敗不一定是失敗, 具體結果可在后臺驗證
}
return true
}
如果需要兼容iOS 9以下版本, 可在下面的方法內處理:
func application(_ application: UIApplication, open url: URL, sourceApplication: String?, annotation: Any) -> Bool {
LQAliPay.open(url: url, success: { (result) in
//處理支付成功結果
}) {
// 支付失敗或支付異常, 這里的支付失敗不一定是失敗, 具體結果可在后臺驗證
}
return true
}
發起支付
在發起支付的事件里添加以下方法的調用:
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)
}
}
后記
關于支付寶返回的支付結果處理, 這里有一個大坑, 具體請參考我的另一篇文章: [iOS]關于支付寶支付返回值的坑
文章涉及的demo在Github LQThirdParty, 歡迎Star | Fork