[AliPay]支付宝支付接入

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

一. 新建APP及安全配置

首先到蚂蚁金服开发平台注册账号, 并新建应用, 配置相关的安全数据, 具体可参考其官方文档一步步进行操作, 这里不再赘述.

二. 集成SDK及配置工程

2.1 集成SDK

下载iOS 端SDK, 将解压后iOSDemo 中的以下两个文件添加到项目:

AlipaySDK.bundle
AlipaySDK.framework

注意: 如果使用Xcode 9 以上版本, 直接拖进去, 并不会形成引用, 会报找不到文件的错误, 这时可以删除引用, 即将文件从项目中删除:

[AliPay]支付宝支付接入_第1张图片
屏幕快照 2017-11-21 上午11.45.26.png

点击 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

[AliPay]支付宝支付接入_第2张图片
屏幕快照 2017-11-21 上午11.51.59.png

在Xcode 9以上版本添加系统库的时候, 会在项目根目录新建一个Frameworks文件夹, 如上图所示, 添加系统库的时候, 会出现在这里, 而在 Link Binary With Libraries 中并没有显示添加的系统库, 这样在编译的时候还是会出错的, 如果第一次添加没有, 可以再添加一次, 务必保证如下图所示:


[AliPay]支付宝支付接入_第3张图片
Link Binary With Libraries

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

[AliPay]支付宝支付接入_第4张图片
Header Search Paths

添加 $(SRCROOT)/项目名称, 如果已有, 则不需添加;

此时编译一下, 应该不会再报错了.

添加URL Scheme
在Info -> URL Types 中, 点击 + 新加一个URL Scheme, 用于支付成功会返回APP.

这里的URL Schemes要根据实际商户的app中填写的独立scheme,建议跟商户的app有一定的标示度,要做到和其他的商户app不重复,否则可能会导致支付宝返回的结果无法正确跳回商户app。

这个值和发起支付时接口中的参数 appScheme 保持一致.

[AliPay]支付宝支付接入_第5张图片
添加URL Scheme

到此, 相关的配置就完成了, 下面就是使用相关的API实现相应的功能.

PS: 如果是Swift项目, 在使用相关API的时候, 需要新建桥接头文件, 或者在已有桥接头文件内引用其头文件:

#import 

三. 支付

支付宝的大部分内容都是由后台完成的, 包括订单生成, 加签, 加密, 秘钥验证等一些安全操作, 最终生成一个编码后的字符串返回给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

(完)

你可能感兴趣的:([AliPay]支付宝支付接入)