一:介绍
最近支付宝,微信,银联支付类sdk均做了更新,其中支付宝sdk变化比较大,由原来需要导入六个文件:
- AlipaySDK.framework
- AlipaySDK.bundle
- Order.h和Order.m
- Until文件夹
- openssl文件夹
- libcrypto.a和libssl.a
在新版之后只需要导入两个文件就可以解决了,文件如下:
- AlipaySDK.framework
- AlipaySDK.bundle
下面我在旧版文章的基础上,为大家详细介绍最新版本支付宝支付开发流程。
因为工作的需要,我先后总结了iOS支付相关的近五类支付开发文章,分别是支付宝支付、支付宝网页支付转客户端、微信支付、银联支付、Apple_pay,做这些总结第一是方便以后的查阅,第二也为大家提供方便, 以免在用到的地方重复踩坑。
注意开始填坑!!!
二:交互流程
建议先把开发文档仔仔细细看一遍,一定要看,刚开始的时候没有老老实实地看完,结果遇到很多的坑,浪费的挺多的时间的,所以建议一定要好好看看,特别是交互流程这一部分。
2.1 功能流程
流程说明:
- 第4步:调用支付接口
- 第5步:支付请求
- 第8步:接口返回支付结果
- 第12步:异步发送支付通知
2.2 数据交互
数据交互说明:
- 构造订单数据并签名
- 发送请求数据
- 手机支付宝支付开发包对请求数据进行处理
- 返回处理的结果数据
- 商户对获取的返回结果数据进行处理
三:下载支付宝SDK
支付宝业务众多,真想找到想要的支付sdk还是要费一番功夫的,这里给出了最新的sdk地址(注意的是下载出来的SDK包里面并没有传说中的开发文档,需要其他地方找或者看网页上的)。
公钥、私钥、PID、sellerID、key这些东西的用途和获取方式在文档上都有详细的说明,这里不再赘述,一定要把概念分清楚再去做,不然一会就乱了。如果遇到问题的话咱们可以再一起探讨。
四: 导入库集成SDK
4.1 导入文件和关键库
官方demo文件
把iOS包中的压缩文件中以下文件拷贝到项目文件夹下,并导入到项目工程中:
- AlipaySDK.framework
- AlipaySDK.bundle
在Build Phases选项卡的Link Binary With Libraries中,增加以下依赖:
其中,需要注意的是:
- 如果是Xcode 7.0之后的版本,需要添加libc++.tbd、libz.tbd;
- 如果是Xcode 7.0之前的版本,需要添加libc++.dylib、libz.dylib(如下图)。
此时,假如你启动工程,很大几率上你会发现报error的情况。
报错#include
这是一个神奇的大坑,我Google了好久,也不得其解,然后经网友提醒之后想起来#import “”和#import <>的区别。
解决方法:Targets -> Build Settings 下的 Header Search Paths。添加如下目录 “$(SRCROOT)/项目名称/文件的绝对地址”
如图:
4.2
在需要调用AlipaySDK的文件中,增加头文件引用。
1 | import <AlipaySDK/AlipaySDK.h> |
4.3 调用支付接口
在支付宝的接入文档中,是将生成一个订单这步放在客户端来做了,但这个最好是 放在服务器端来做。
后台生成订单然后拼接,签名,然后服务器端直接给客户端传一个加密签名过的参数就可以了,这样比较安全。
所有的订单信息,商户信息等都掌握在自己的手中,这样的话APP端就不怕被拦截数据,并且调用起来也就特别简单了,只需要调用支付的接口。
如果只需要发送订单和处理支付返回结果,只需要添加AlipaySDK.bundle和AlipaySDK.framework这两个就行了,下载的SDK中很容易发现。
快捷支付方法是这个:1
-(void)payOrder:(NSString *)orderStr fromScheme:(NSString *)schemeStr callback:(CompletionBlock)completionBlock;
在支付的按钮中,使用支付宝这个类,再调用这个方法就行啦!如下如:1
2
3
4
5[[AlipaySDK defaultService] payOrder:credential fromScheme:fromScheme callback:^(NSDictionary* resultDic) {
NSLog(@"%@",resultDic);
}];
4.4 配置支付宝客户端返回url处理方法
如示例AliSDKDemo\APAppDelegate.m文件中,增加引用代码:1
import <AlipaySDK/AlipaySDK.h>
在@implementation AppDelegate中以下代码中的NSLog改为实际业务处理代码:
1 | - (BOOL)application:(UIApplication *)application |
4.5 项目配置
最后,不要忘了还要写一个URL Scheme,在Targets -> Info 下最后一个即可找到,
点击“Info”选项卡,在“URL Types”选项中,点击“+”。
到这里支付宝支付就基本完成了,如果小伙伴们在集成过程中遇到什么问题,可以留言给我或者添加qq,在线帮你解决。