iOS 最新版本支付宝支付开发流程

5,134 阅读5分钟

一:介绍

最近支付宝,微信,银联支付类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 数据交互

数据交互图

数据交互说明:

  1. 构造订单数据并签名
  2. 发送请求数据
  3. 手机支付宝支付开发包对请求数据进行处理
  4. 返回处理的结果数据
  5. 商户对获取的返回结果数据进行处理

三:下载支付宝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 <openssl/opensslconf.h> not find 这是一个神奇的大坑,我Google了好久,也不得其解,然后经网友提醒之后想起来#import ""和#import <>的区别。

解决方法:Targets -> Build Settings 下的 Header Search Paths。添加如下目录 "$(SRCROOT)/项目名称/文件的绝对地址" 如图:

3.png

4.2

在需要调用AlipaySDK的文件中,增加头文件引用。

import <AlipaySDK/AlipaySDK.h>

4.3 调用支付接口

在支付宝的接入文档中,是将生成一个订单这步放在客户端来做了,但这个最好是 放在服务器端来做。 后台生成订单然后拼接,签名,然后服务器端直接给客户端传一个加密签名过的参数就可以了,这样比较安全。 所有的订单信息,商户信息等都掌握在自己的手中,这样的话APP端就不怕被拦截数据,并且调用起来也就特别简单了,只需要调用支付的接口。 如果只需要发送订单和处理支付返回结果,只需要添加AlipaySDK.bundle和AlipaySDK.framework这两个就行了,下载的SDK中很容易发现。 快捷支付方法是这个:

-(void)payOrder:(NSString *)orderStr fromScheme:(NSString *)schemeStr callback:(CompletionBlock)completionBlock;

在支付的按钮中,使用支付宝这个类,再调用这个方法就行啦!如下如:

[[AlipaySDK defaultService] payOrder:credential fromScheme:fromScheme callback:^(NSDictionary* resultDic) {
            
    NSLog(@"%@",resultDic);
          
}];

4.4 配置支付宝客户端返回url处理方法

如示例AliSDKDemo\APAppDelegate.m文件中,增加引用代码:

import <AlipaySDK/AlipaySDK.h>

在*@*implementation AppDelegate中以下代码中的NSLog改为实际业务处理代码:

- (BOOL)application:(UIApplication *)application
            openURL:(NSURL *)url
  sourceApplication:(NSString *)sourceApplication
         annotation:(id)annotation {
    
    if ([url.host isEqualToString:@"safepay"]) {
        //跳转支付宝钱包进行支付,处理支付结果
        [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
            NSLog(@"result = %@",resultDic);
        }];
    }
    return YES;
}

// NOTE: 9.0以后使用新API接口
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options
{
    if ([url.host isEqualToString:@"safepay"]) {
        //跳转支付宝钱包进行支付,处理支付结果
        [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
            NSLog(@"result = %@",resultDic);
        }];
    }
    return YES;
}

4.5 项目配置

最后,不要忘了还要写一个URL Scheme,在Targets -> Info 下最后一个即可找到, 点击“Info”选项卡,在“URL Types”选项中,点击“+”。

项目配置

到这里支付宝支付就基本完成了,如果小伙伴们在集成过程中遇到什么问题,可以留言给我或者添加qq,在线帮你解决。

关注 【网罗开发】微信公众号,网罗天下方法,方便你我开发,更多iOS技术干货等待领取,所有文档会持续更新,欢迎关注一起成长!

希望可以帮助大家,如有问题可加QQ群: 668562416 交流

如果哪里有什么不对或者不足的地方,还望读者多多提意见或建议

如需转载请联系我,经过授权方可转载,谢谢