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 <AlipaySDK/AlipaySDK.h>

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<NSString*, id> *)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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 学而时习之,不亦悦乎,大家好,我是张杰。 iOS开发支付模块分为两个部分: 1、调取外部支付,例如支付宝、微信、银...
    杰小冷_4957阅读 5,840评论 0 2
  • 最近项目用到支付宝支付,第一次自己做支付,简直无从下手,一路瞎闯 总算是成功了. 这里记录一下,以备后用 首先两个...
    LinkStart阅读 5,748评论 0 3
  • 前期准备 接入前期准备工作包括商户签约和密钥配置,已完成商户可略过。 下载支付宝SDK支付宝SDK下载地址 SDK...
    TianBai阅读 8,811评论 16 104
  • 实现支付宝支付的准备工作: 1.向支付宝签约,成为支付宝的商户 签约完成后,支付宝会提供一些必要的数据给我们 商户...
    Anson杨春安阅读 12,659评论 0 6
  • 这次是一个新项目,集成支付宝和微信支付,客户端集成其实非常简单,主要参数和配置都是可以在后台完成。不过还是碰到了一...
    善良的karl阅读 5,227评论 0 1

友情链接更多精彩内容