iOS支付技术程序员iOS Developer

支付__支付宝App支付接入流程(一)

2017-04-13  本文已影响531人  小白哥有话说

不理解支付功能集成的什么商户端,用户端,支付平台端没关系,本篇以本人集成支付宝已经成功了为例,解读支付宝的SDK集成流程:
一般任何的技术学习都要先由Demo逐步去学习:
本篇就一支付宝的Demo为例教您如何快速集成!
亲测可用,抓紧学习吧!

本篇目录:
一.导入对应的库
二.快速接入方式:
三.注意事项:

一.导入对应的库

1.导入以下系统库
在Build Phases选项卡的Link Binary With Libraries中,增加以下依赖:

// 支付宝SDK依赖的
libc++.tbd
libz.tbd
SystemConfiguration.framework
CoreTelephony.framework
QuartzCore.framework
CoreText.framework
CoreGraphics.framework
Foundation.framework
UIKit.framework
CoreMotion.framework
CFNetwork.framework

// 支付宝依赖的(要在导入AlipaySDK.framework库之后才能加入)
AlipaySDK.framework

2.2个.a静态库和1个framework 和一个bundle文件,共计4个库(在Demo中查找),如下:

libcrypto.a
libssl.a
AlipaySDK.framework
AlipaySDK. bundle

3.导入demo中的2个文件夹,如下:

openssl
Util

导入效果如下:

导入的外库,共计6个文件.png

Build,编译发现会报以下错误
报错 : #include <openssl/asn1.h> 找不到
解决方案:
在Build Settings选项卡中搜索 header search添加新的路径为$(PROJECT_DIR)/FarmAndAnimal/Vendor/AliPaySDK/
其中这里的AliPaySDK 指的是openssl 的上一级文件为止,不一定是AliPaySDK, 切记!

二.快速接入方式:

  1. Appdelegate
    头文件
#import  <AlipaySDK/AlipaySDK.h>

代码(Code)
Appdelegate 中加入以下代码,原封不动的!(这里以只集成支付宝的为例,后期总结集成所有的支付的处理办法)

- (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);
        }];
        
        // 授权跳转支付宝钱包进行支付,处理支付结果
        [[AlipaySDK defaultService] processAuth_V2Result:url standbyCallback:^(NSDictionary *resultDic) {
            NSLog(@"result = %@",resultDic);
            // 解析 auth code
            NSString *result = resultDic[@"result"];
            NSString *authCode = nil;
            if (result.length>0) {
                NSArray *resultArr = [result componentsSeparatedByString:@"&"];
                for (NSString *subResult in resultArr) {
                    if (subResult.length > 10 && [subResult hasPrefix:@"auth_code="]) {
                        authCode = [subResult substringFromIndex:10];
                        break;
                    }
                }
            }
            NSLog(@"授权结果 authCode = %@", authCode?:@"");
        }];
    }
    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);
        }];
        
        // 授权跳转支付宝钱包进行支付,处理支付结果
        [[AlipaySDK defaultService] processAuth_V2Result:url standbyCallback:^(NSDictionary *resultDic) {
            NSLog(@"result = %@",resultDic);
            // 解析 auth code
            NSString *result = resultDic[@"result"];
            NSString *authCode = nil;
            if (result.length>0) {
                NSArray *resultArr = [result componentsSeparatedByString:@"&"];
                for (NSString *subResult in resultArr) {
                    if (subResult.length > 10 && [subResult hasPrefix:@"auth_code="]) {
                        authCode = [subResult substringFromIndex:10];
                        break;
                    }
                }
            }
            NSLog(@"授权结果 authCode = %@", authCode?:@"");
        }];
    }
    return YES;
}

2.在要支付的功能类中导入以下代码

头文件:

#import "RSADataSigner.h"
#import <AlipaySDK/AlipaySDK.h>

代码(Code):

// NOTE: 调用支付结果开始支付
//应用注册scheme,在AliSDKDemo-Info.plist定义URL types
 NSString *appScheme = @"FarmBB";
 [[AlipaySDK defaultService] payOrder:result.data fromScheme:appScheme callback:^(NSDictionary * resultDic) {
                        NSLog(@"reslut = %@",resultDic);
                    }];

注意:2个参数解释:
在请求订单成功后,支付宝返回一坨字符串,如上为result.data ,以及支付成功后回调到自己应用的标示为appScheme ,然后按照上面的进行传递,在resultDic 中接受是否支付成功,如下:

 NSString *resultStatus = resultDic[@"resultStatus"];
            NSString *errStr = resultDic[@"memo"];
            switch (resultStatus.integerValue) {
                case 9000:// 成功
                    break;
                case 6001:// 取消
                    break;
                default:
                    break;
            }

3.修改urlSchemes,按照如下图所示,添加回调的url schemes ,注意要同上面的appScheme 保持一致,这样可以保证支付成功还是失败都能回到我的应用中。

修改我的urlSchemes.png

三.注意事项:

1.报错的原理处理

#include <openssl/asn1.h> 找不到,原因是因为没有找到对应的路径,注意这里是<> 会从根目录去寻找,所
以如果设置路径到 openssl的上一级就可以找到,就解决了这个报错!

2.Appdelegate中的方法解释:
下面的方法iOS9之前跳到支付宝返回判断是否支付成功,或者订单已经下了,但是还没有支付,就在这个方法中处理!

- (BOOL)application:(UIApplication *)application
            openURL:(NSURL *)url
  sourceApplication:(NSString *)sourceApplication
         annotation:(id)annotation

下面的方法iOS9之后跳到支付宝返回判断是否支付成功,或者订单已经下了,但是还没有支付,就在这个方法中处理

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options

3.支付流程说明:

(1).首先由客户端发出下订单的请求--->我们的服务端响应并把自己的请求返回订单信息,说明下订单成功!
(2).其次客户端继续把服务端返回的字符串以及自己的appScheme 发给支付宝的客户端App --->调起支付宝的客户端(或者H5网页)--->客户端付款完成 --->支付宝把信息发给--->支付宝服务端 --->支付宝服务端返回支付情况给支付宝客户端
(3).支付宝客户端告知我们的商家App--->商家App显示是否支付成功
(4).同时支付宝服务端会异步通知我们的商家服务端App告知是否支付成功

附上交易的图片如下:


支付宝交易流程图.png

4.一定要记得修改urlSchemes
后期会把微信支付,银联银联支付等以及此三者的对接等写一个完整的Demo整理下,以供学习!

附上支付宝iOS端集成流程,貌似没什么用!
https://doc.open.alipay.com/docs/doc.htm?spm=a219a.7629140.0.0.sFUG6d&treeId=204&articleId=105295&docType=1

有什么问题,可以加QQ:1824496534,备注:支付
欢迎相互指导,一起进步!
----- 来自DaviD

上一篇 下一篇

猜你喜欢

热点阅读