关于集成支付宝支付网上也有很多流程和教程了 ,不过可能有些是以前的版本,大家也可以自行参考一下,不过接下来我要说的是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
如果以上的方法帮助到你了,欢迎分享,欢迎私信和我交流。
网友评论