文章涉及的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