做APP支付已经做了两三次了,每次都要花点时间去调试回调,很浪费时间,所以这次总结了一下我们需要在AppDelegate中做的事情。本文已经总结并解析了常用的错误码errorCode:

    首先,遵守微信协议<WXApiDelegate>。

    其次,需要注意的就是版本适配问题了,这个地方贴出两个版本适配的常用代码(宏定义/预编译宏),大家自行去了解相关用法:

/*不是我不说怎么用,因为我也搞不清楚怎么用才是准确的,里面有许多坑,还有其他适配方法,比如 if (@available (iOS 10.0, *)) { //这里执行iOS10.0以上的代码片段}。

__IPHONE_OS_VERSION_MAX_ALLOWED 允许最高的系统版本

__IPHONE_OS_VERSION_MIN_REQUIRED 要求最低的系统版本

*/

1.直接贴代码了,分别实现两个方法(系统版本适配),注意方法内部的代码是一样的!

#pragma mark - 微信、支付宝支付配置

//iOS 2.0-9.0

//- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{

//    return YES;

//}

//iOS 4.2-9.0

- (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);

            [self alipayResult: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?:@"");

        }];

    }else if ([url.host isEqualToString:@"pay"]){//② 微信支付回调

        [WXApi handleOpenURL:url delegate:self];

    }

    return YES;

}

//iOS 9.0以后

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

      //这里的代码直接拷贝上面的,iOS9.0以上的版本会走这里。

  }

2.实现微信回调代理

#pragma mark -- WXApiDelegate 实现微信回调代理

- (void)onResp:(BaseResp *)resp{

    //判断是否是微信支付回调 (注意是PayResp 而不是PayReq)

    if ([resp isKindOfClass:[PayResp class]]){

        //支付返回的结果, 实际支付结果需要去微信服务器端查询

        switch (resp.errCode) {

            case WXSuccess:

                [self sendNotificationToSkipPayResult];

                break;

            default:

                [self onPayFail:resp.errCode];

                break;

            }

        }

}

3.自己封装的方法,解析回调信息

#pragma mark -- 微信支付失败结果解析

- (void)onPayFail:(int)errCode {

    NSString *message = nil;

    if (errCode == WXErrCodeCommon) {

        message = @"支付失败";

    } else if (errCode == WXErrCodeUserCancel) {

        message = @"用户取消支付";

    } else if (errCode == WXErrCodeSentFail) {

        message = @"支付失败";

    } else if (errCode == WXErrCodeAuthDeny) {

        message = @"授权失败";

    } else if (errCode == WXErrCodeUnsupport) {

        message = @"未知错误";

    } else {

        message = @"未知错误";

    }

    if (!kIsEmptyString(message)) {

        //支付失败后的回调

        [self sendNotificationToPayFail:message];

    }

}

#pragma mark -- 支付宝支付结果处理

- (void)alipayResult:(id)result{

    NSDictionary * dic = (NSDictionary *)result;

    NSString * errorCode = [dic objectForKey:@"resultStatus"];

    NSString * resultStr = [dic objectForKey:@"result"];

    NSString *message;

    BOOL isPaySuccess = NO;

    /*

    在支付过程结束后,会通过 callbackBlock 同步返回支付结果。

    返回结果需要通过 resultStatus 以及 result 字段的值来综合判断并确定支付结果。 在 resultStatus=9000,并且 success="true"以及 sign="xxx"校验通过的情况下,证明支付成功。其它情况归为失败。较低安全级别的场合,也可以只通过检查 resultStatus 以及 success="true"来判定支付结果。*/

    if ([@"9000" isEqualToString:errorCode]) {

        NSString * success;

        if (resultStr) {

            NSArray *array = [resultStr componentsSeparatedByString:@"&"];

            if (array && [array count]>0) {



                for (int i=0; i<[array count]; i++) {

                    NSString * subStr = [array objectAtIndex:i];

                    if ([subStr rangeOfString:@"success=\""].location != NSNotFound) {

                        NSArray *signArr = [subStr componentsSeparatedByString:@"="];

                        success = [signArr objectAtIndex:1];

                        break;

                    }

                }

            }

        }

        if ([@"\"true\"" isEqualToString:success]) {

            message = @"支付成功!";

            isPaySuccess = YES;

        }else{

            message = @"未知错误";

        }



    }else if ([@"8000" isEqualToString:errorCode]) {

        message = @"正在处理中";

    }else if ([@"4000" isEqualToString:errorCode]) {

        message = @"支付失败";

    }else if ([@"6001" isEqualToString:errorCode]) {

        message = @"用户取消支付";

    }else if ([@"6002" isEqualToString:errorCode]) {

        message = @"网络连接失败,请稍后重试!";

    }else{

        message = @"未知错误";

    }

    if (isPaySuccess) {

        [self sendNotificationToSkipPayResult];

    }else {

        if (!kIsEmptyString(message)) {

            //支付失败后的回调

            [self sendNotificationToPayFail:message];

        }

    }

}

4.通知支付页面

#pragma mark -- 支付成功后通知 (微信、支付宝 支付成功通知支付页面处理跳转)

- (void)sendNotificationToSkipPayResult {

//   [ [NSNotificationCenter defaultCenter] postNotificationName:@"通知名字" object":nil];

}

#pragma mark -- 支付失败后通知  (微信、支付宝 支付失败通知支付页面处理提示信息)

//参数:failReason:失败原因

- (void)sendNotificationToPayFail:(NSString *)failReason{

    NSLog(@"%@",failReason);

//  [ [NSNotificationCenter defaultCenter] postNotificationName:@"通知名字" object":failReason];

}




本文没有调起支付等其它集成步骤的教程,只是处理了回调。所以有其它无法解决的问题可以留言,收到通知我