ios开发——支付宝SDK集成流程

来源:互联网 发布:性玩具知乎 编辑:程序博客网 时间:2024/05/02 04:47

1、创建应用

这个其实开发者们都应该懂,就是在支付宝这里挂个号,然后进行下一步业务的申请。

创建应用的链接


创建应用界面

开发者只需要按照指示一步一步添加内容就可以。

2、申请移动支付

这个就需要一些公司文档什么的了,根据指示填写即可,但是要切记不要让自己的word超过了大小限制,否则有一定几率不会通过。
签约成为商家


虽然说,整个流程可能需要将近两周时间,但是根据我这次集成来看,大约一周多就能完成。但是假如你的开发周期比较紧张,建议早申请,毕竟要控制时间成本。

3、下载官方Demo

这个是比较坑的事情。。。不知道是不是公司原来办公室网络的问题,总之就是用迅雷无论如何也下载不下来,然后用了chrome之后就一切顺利。

开发工具包下载

点击以上链接之后进入各种Demo的下载页面,当然,也可以下载用于UI的视觉资源。(PS:Android和iOS的Demo是在一起的

以下两张图片为下载的Demo的文件情况:


Demo内部文件

Demo内部文件

因为我是做iOS端的集成,所以自行忽略掉了服务端和Android端的Demo。

4、业务逻辑

交互流程网页链接


功能流程

数据交互

支付宝支付的功能流程相比较微信支付来说简单的很,如上面两张图展示的,我们的App(也就是商户客户端)所做的大概只有三个步骤:

  • 生成订单
  • 调用支付宝接口,发送订单
  • 返回订单支付结果并处理

功能层面上讲就是着这些,但是支付环节肯定有一个安全性问题,那么就需要加密以及解密的过程。

目前支付宝采取的是RSA的加密方式,这是一种比较常见的非对称加密算法,至于怎么集成,下面会给大家做个详细介绍。RSA维基

5、集成


iOS工程内容

1)添加framework和其他文件

打开iOS工程,你会看到上面的一堆东西,你需要复制粘贴到自己工程里的有:

  • lipaySDK.framework
  • AlipaySDK.bundle
  • Order.h和Order.m
  • Until文件夹
  • openssl文件夹
  • libcrypto.a和libssl.a

2)添加第三方框架和类库


来源于网络,侵删


以及上面的libcrypto.a , libssl.a

此时,假如你启动工程,很大几率上你会发现报error的情况。
报错#include <openssl/opensslconf.h> not find
这是一个神奇的大坑,我Google了好久,也不得其解,然后经网友提醒之后想起来#import ""#import <>的区别。

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

在集成之前,不要忘了还要写一个URL Scheme,在Targets -> Info 下最后一个即可找到。


3)集成代码

你在添加代码的时候会发现下图所示代码


  • partner:可以在支付宝的账户中找到
  • seller:就是我们的支付宝账号
  • privateKey:这个就是我们上面提到的RSA加密中的密钥

密钥生成方法在上文中可以看到,就是在上文中的下载的官方文档中openssl文件夹中的生成命令。

RSA私钥及公钥生成


网页截图

注意:我在生成密钥的时候,在第三行,误将其以为是Java开发者才会使用,所以没有在命令行中输入命令,一直导致无法加密,所以iOS开发者务必将所有命令输入Vim当中。

生成的文件一共有两个rsa_private_key.pemrsa_public_key.pem,第一个就是私钥,可以用vim打开,也可以用文本文件打开,打开之后复制到工程中即可,值得注意的是,复制的时候不要有空格等东西。。。

上传公钥:

上传公钥官方指导,和私钥一样,上传的过程中,切记不要有空格等字符出现。

AppDelegate

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

}

执行回调

    orderString = [NSString stringWithFormat:@"%@&sign=\"%@\"&sign_type=\"%@\"",                   orderSpec, signedString, @"RSA"];    [[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {        NSLog(@"reslut = %@",resultDic);    }];

以下是几个回调返回的resultDic值:

9000 订单支付成功 8000 正在处理中  4000 订单支付失败 6001 用户中途取消 6002 网络连接出错

对于iOS9进行适配

和其他的第三SDK一样,对于新的iOS9,支付宝SDK一样需要下infoPlist进行适配。

<key>NSAppTransportSecurity</key>   <dict>           <key>NSExceptionDomains</key>           <dict>              <key>alipay.com</key>          <dict><!--Include to allow subdomains--> <key>NSIncludesSubdomains</key><true/><!--Include to allow insecure HTTP requests-->     <key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key> <true/>         <!--Include to specify minimum TLS version-->         <key>NSTemporaryExceptionMinimumTLSVersion</key>         <string>TLSv1.1</string>      </dict>   </dict></dict>

4)易发bug以及总结

我觉得最易发的有:

  • 报错#include <openssl/opensslconf.h> not find
  • 返回错误ALI64和ALI69

第一个上面有提到,第二个可以在支付包官方文档中找到:官方链接。
理论上讲,最大概率出错就是在公钥和密钥的处理上,认真排查应该就会找到问题。
如果还没有解决,可以寻找客服来解决问题,刚开始的是智能机器人客服,如果两次都无法解决问题,还可以后面申请人工客服,只不过等待时间可能会有点长。



文/Derek_老黄(简书作者)
原文链接:http://www.jianshu.com/p/0f3bb4c2c473
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
0 0
原创粉丝点击