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

1、创建应用

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

创建应用的链接


创建应用界面

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

2、申请移动支付

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


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

3、下载官方Demo

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

开发工具包下载

点击以上链接之后进入各种Demo的下载页面,当然,也可以下载用于UI的视觉资源。(PS:AndroidiOS的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
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值