iOS最新快速集成支付宝支付并支付成功(2022年版)

关于集成支付宝支付网上也有很多流程和教程了 ,不过可能有些是以前的版本,大家也可以自行参考一下,不过接下来我要说的是2022年版本目前最新的流程,使用的是cocopods快速集成的方式。同时这里也说明一下为什么使用cocopods的方式,而不是采用手动集成的方式:
1、cocopods方式相比较而言,更简单和省时省力,比如手动集成的话,需要手动添加很多库和文件,容易出错;
2、cocopods方式对于项目的后续维护和升级提供了便利,升级SDK只需要执行一下cocopods命令就可以了。

那接下来闲话不叙,直接开搞,步骤如下:

1、Podfile文件中加入如下内容:

pod  'AlipaySDK-iOS'

然后在终端里执行命令

pod update --no-repo-update

2、在AppDelegate.m文件中导入头文件,其他地方需要引用的地方也是这么引入

# import 

3、在AppDelegate.m文件的 @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 *)options
{
    if ([url.host isEqualToString:@"safepay"]) {
        //跳转支付宝钱包进行支付,处理支付结果
        [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
            NSLog(@"result = %@",resultDic);
        }];
    }
    return YES;
}

4、点击项目名称,点击 Info 选项卡,在“URL Types”选项中,点击“+”,在“URL Schemes”中输入一串独特而唯一的字符串,比如:“alisdkdemo”。个人建议可以使用bundleid去掉点号(.)后的字符串,比如bundleid为:com.baidu.niubi,那么这里我们就可以使用combaiduniubi,因为bundleid已经保证了了唯一性,所以使用这个就不太会重复。
注意:这里的 URL Schemes 中输入的 alisdkdemo,为测试 demo,实际商户的 app 中要填写独立的 scheme,建议跟商户的 app 有一定的标示度,要做到和其他的商户 app 不重复,否则可能会导致支付宝返回的结果无法正确跳回商户 app。

5、发起支付,组装请求信息,这个阶段需要把后台把信息组装好,这个应在 商户服务端 完成,商户服务端直接将组装和签名后的请求串 orderString 传给客户端,客户端直接传给 SDK 发起请求。示例代码如下:

 NSString *appScheme = @"combaiduniubi";
        // NOTE: 将签名成功字符串格式化为订单字符串,请严格按照该格式
        NSString *orderString = [response stringWithKey:@"pay_apptrade"];

        // NOTE: 调用支付结果开始支付
        [[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {
            
            DLog(@"reslut = %@",resultDic);
            
            NSInteger resultStatus = [[resultDic stringWithKey:@"resultStatus"] integerValue];
            
            switch (resultStatus) {
                case 9000:{//订单支付成功
                    
                    [MBProgressHUD showSuccess:XMFLI(@"支付成功") toView:[kApplication.windows lastObject]];
                    
                }
                    break;
                case 8000:{//正在处理中,支付结果未知
                    
                    [MBProgressHUD showError:XMFLI(@"正在处理中...") toView:[kApplication.windows lastObject]];
                    
                }
                    break;
                case 4000:{//订单支付失败
                    
                    [MBProgressHUD showError:XMFLI(@"支付失败") toView:[kApplication.windows lastObject]];
                    
                }
                    break;
                case 5000:{//重复请求
                    
                    [MBProgressHUD showError:XMFLI(@"重复请求") toView:[kApplication.windows lastObject]];
                }
                    break;
                case 6001:{//用户中途取消
                        
                    [MBProgressHUD showError:XMFLI(@"中途取消") toView:[kApplication.windows lastObject]];
                }
                    break;
                case 6002:{//网络连接出错
                        
                    [MBProgressHUD showError:XMFLI(@"网络连接出错") toView:[kApplication.windows lastObject]];
                    
                }
                    break;
                case 6004:{//支付结果未知
                        
                    [MBProgressHUD showError:XMFLI(@"支付结果未知") toView:[kApplication.windows lastObject]];
                    
                }
                    break;
                    
                default:{//其他支付错误
                    
                    [MBProgressHUD showError:XMFLI(@"支付出错了") toView:[kApplication.windows lastObject]];
                }
                    break;
            }
            
            
            
            
        }];

注意:经官方确认,实现这个方法唤起支付宝钱包app支付的时候,是不会走callback这个回调的,会走AppDelegate里面实现的回调方法。只有在调起h5网页支付的时候,才会走callback这个回调方法。

6、回调处理

- (BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary *)options

{

    if ([url.host isEqualToString:@"safepay"]) { //支付宝支付的回调

        //跳转支付宝钱包进行支付,处理支付结果

        [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {

            QDLog(@"支付结果 = %@",resultDic);

            NSIntegerresCode = [resultDic[@"resultStatus"]integerValue];

            if(resCode ==9000) {//支付成功

                //发送支付成功的通知

                [[NSNotificationCenter defaultCenter] postNotificationName:NoticePaySuccess object:nil];

            }elseif(resCode ==6001){//用户中途取消

                //发送支付取消的通知

                [[NSNotificationCenter defaultCenter] postNotificationName:NoticePayCancel object:nil];

            }else{

                 [[NSNotificationCenter defaultCenter] postNotificationName:NoticePayFailure object:nil];

            }

        }];

    }

    return YES;

}

到此为止,支付宝支付的集成和使用就算完成了。
最后也附上支付宝官方的开放文档地址:https://opendocs.alipay.com/open/204/105295

如果以上的方法帮助到你了,欢迎分享,欢迎私信和我交流。

你可能感兴趣的:(iOS最新快速集成支付宝支付并支付成功(2022年版))